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Tell me about YOURSELF Daily Activities 


How you are implementing 


AGILE in your current project? 


Main Responsibilities as an SDET 
(Sprint Ceremony) 


Tell me about yourself e 


First of all, | would like to thank you for giving me this opportunity to interact with a relational database and and JDBC for database 


and | really appreciate your time. testing. | am also comfortable with the Data Driven (DDD) 
Frameworks. 

l've been working in the IT industry for 8 years. Throughout my 

career I've specialized in automation, but | was also involved and!  - | have worked on API testing on my project and | used POSTMAN 

am very comfortable with manual and back-end testing. and REST ASSURED LIBRARY for API testing. 

Currently, | am holding an SDET position in my team and my main  - | achieve continuous integration and schedule my test executions 


responsibilities are to design, develop and maintain Test Automation by using Jenkins. 


F k th ifi i i l . 
RAE WODSHISOVCNHESUSEISEONESInO SYSTEM ENUI EENT - I'm familiar with Agile ENVIRONMENTS and currently I'm working 


| have hands on experience on UI, API and DataBase testing. My role in a Scrum Team and proficient in all sprint-related Scrum 
in my company includes running FUNCTIONAL TEST, SMOKE TEST ceremonies. 


uM Lc - | am a certified SCRUM MASTER and OCA certification (ORACLE 
JAVA PROGRAMMER). 
- | have specialized in JAVA. | used SELENIUM as a testing tool with 
CUCUMBER BDD framework. | developed my "testing framework" 
from scratch based on Page Object Model (POM) and I have worked 
with MAVEN as a build management tool and SELENIUM with JUnit 
testing framework. | have also worked with TestNG and Data Driven - | can work well individually and in a team. | am detail oriented, a 
Testing using Apache POI. quick learner, passionate about learning new skills and new 
technology, and always make sure | meet the deadlines. That's 
pretty much about myself. 


-| am a cross- functional team member. As far as soft skill 
concerned, | consider myself a positive person, adaptable to 
changing circumstances, 


- | use GIT for version control and | also use JIRA for bug tracking and 
project management tool. 


- | have extensive knowledge of SQL queries and | used POSTGRESQL 


Tell me about your Project e 


* My current project is a web-based loan application. 


o As you can see from my resume, | am currently working in a loan company that works 
with small companies. | am working for loan authorization department. 


o The application we are responsible for is mainly developed to store the all required 
information about the customer and share it with the company headquarter. It also 
generates the details of the status of all pending, denied and authorized loan 
applications. 


o As an SDET my main responsibly is automating the UI part of the application, but | am 
also aware of the back end and database part of the application. 


o My role in this project includes running regression, smoke and functional testing. As a 
cross functional team member, | also | help manual testing when required. 


Daily Activities A 


e My daily activities at work, | go to work early in the morning and check result report of 
Smoke Test to make sure that environment is up and running and the application is stable 
or not for the day. 


e |f something goes wrong, | will send out an email to my team so they can take care of it 
asap before everyone comes to work, to reach maximum productivity. 


e And then | check my email if there are any important tasks or notices, also check my 
schedule if there are any meetings for the day and also check Jira to review what needs 
to be done that day in which priority. 


* Then go to attend daily standup meeting at 10:00 am. with my scrum team to talk about 
what we did yesterday, what we will do today and are there any impediments in my way. 
This meeting is simply to synchronize our team and it takes about 15 minutes. 


* After that, | go back to my desk and start automating test cases from regression suits. 
And also, | automate test cases from sprint backlog after doing manually if it is passed. 


e That is pretty much about my daily activities at work. 


Role A 


As an automation engineer, | develop my ‘testing framework’ based on POM (Page Object Model). I 
performed various types of testing, like; functional testing, smoke testing, regression testing and back-end 
testing. | am responsible executing Regression test when developers add new functionality to the 
application or end of the sprints. 


| am also responsible to check report of Smoke Test to make sure that environment is up and running first 
thing in the morning. 


If there are any issues, | analyze them. 

If it is service issue, I will immediately contact developers. 
If it is about my scripts, | debug my scripts and fix it. 

If it is a bug, | re-produce it and log the defect. 


And also | am using Jira as bug management tool. Once the bug reports fixed by the developers, | re-test it 
and if it is passed I close it. If the defect is not fixed, | re-open it. Also, as a part of the Agile Scrum Team, | 
participate in the several walkthroughs meeting for the requirement reviews and provide valuable 
feedback to the BA. Lastly, | am cross-functional team member that is always willing to help my team in any 
way to achieve our sprint goal. 


That is pretty much about my role as an automation engineer. 


Framework 


My framework is written using Java OOP language. Java is 
a powerful and robust programming language and 
selenium with java is an opensource and has a large 
community that support each other. 


Selenium WebDriver is a library/tool/API which is used to 
automate the browser, it interacts with the browser. It 
used for UI automation testing. 


My framework is created as a maven project; maven is 
used to manage dependencies and also run our tests, as 
mvn goals from terminal. 


We use Junit as a testing tool. Junit is used to kick off 
cucumber tests and also do assertions. 


In my framework we are using POM according to which 
has separate class for every pages of the application. 


My framework uses a singleton pattern to share the 
WebDriver instance between different classes. 


| have in my framework configuration.properties file to 
store the important test data, like usernames, passwords, 
url's, browsers etc.. 


A 


In my Utilities package | have reusable utilities which can 
be used across different classes of my framework, like 
waits that | need to use always, ConfigurationReader that 
reads my configuration.properties file, and My Driver that 
| can choose which browser I will use in this test case... 


(Types of tests) My framework can test the UI, Back-end 
and API 


We used Cucumber to write test cases, requirements, 
specifications in a GHERKIN language understandable by 
non-tech people 


My framework generates detailed HTML and JSON reports 
with is easy to read and understand to non-technical team 
members. My reports have details test steps and 
screenshots for any failures that may occur. It can also do 
metrics on what percentage is passing, failing, skipped etc. 


We use Git, Github for Version Control. 


* As a Continuous Integration/Deployment tool we use 


Jenkins. 


Team Structure 


A 


e My team consist of adaptive, cross-functional and self-organized individuals 
that highly motivated and knowledgeable. We have 11 people in my team. 


- 5 developers 
- 3 Testers 

- 1 SM 

- 1 PO 

- 1 BA 


(Jacobs, Suzan, Tim, Alejandra, Megane), 
(Irina, Alex, me) 

(John) 

(Brian) 

(Shaun) 


| "m" N 
Main Responsibility as an SDET? 


e Turn manually executed test scenarios into automatically executed test 
scenarios via a Selenium, Java and Cucumber testing framework and 
Gherkin. 


e Design and develop test plans that verify user stories and system 
requirements. 


e Develop and automate test cases to ensure what we build meets the 
highest levels of quality. 


e Functional Testing, Regression Testing, Smoke Testing 


Agile experience in your most recent project 


Our sprint is 2 weeks and we have release every 3 sprints as a release cycle. We have 11 people in my team. 5 
developers , 3 testers, also 1 SM, 1 BA and 1 PO. 


We start a sprint with Sprint Planning Meeting and we learn the part of the application which we are going to develop. 
We get general idea than we do Sprint Grooming for giving some estimates for the tasks. 


After sprint starts, we do Daily Standup Meeting everyday morning and we discuss what did we do yesterday, what will 
we do today and is there any blocker. Just we synchronize info about the sprint. 


End of the sprint, usually we do Sprint Demo/Review Meeting . It is just to show customer what we build throughout 
the sprint. PO puts feedback. As an SDET in my team, I have done presentation sometimes and go over through the 
functionalities in the meeting room. Client or stakeholders or business people they ask questions what they don't 
know or what they want to know. 


After Sprint Demo, we do Sprint Retrospective Meeting. In Sprint Retro, we talk about what was good in last sprint, 
what kind of mistakes we made. We go over them and make sure that we don't make the same mistakes again. If we 
did something good , we would continue doing it. 


This is pretty much our Sprint process 


SOFT SKILL TESTING a 


* Software Testing? * |f Developer says not a defect, what to 
2 
e Why we test? do? 
è i ? 
* Test Plan Vs Test Strategy When will you Automate? 
© Test Plan? * When will you not Automate? 
© Test Case? * Debugging vs testing? 
; e i ? 
* When the testing starts? Peer review? 
2 Bere: edes * Who writes test plans and test cases? 
DeTect LITE Cycler 
* Epic, User stories & Tasks? * Bug severity vs bug priorit 
MM er teresa * System testing and integration testing? 
Avhat Is testing nierarcny: 
* Requirement Traceability Matrix (RTM) ' Black box vs white box testing? 
S Bere * Front End Testing and Back End testing? 


anao do when eU TED EIS Tero n ELUTATS EST ES HUCSESIR See co t URS eR 
EDEN ORO ee eee 
testing 


Software Testing? e 


* Process of executing a program or application with the intent of find 
software bugs using functional and automation tools 


* Process of validating/verifying a software program/application 


Why we test? 


* To build bug free application. 
* To satisfied end user and client. 
* To build great product to generate more revenue. 


» 


Is 10096 testing possible? A 


e We can’t test the application 100% since there are unlimited scenarios that 
we can’t even imagine. 


e Software testing is risk based activity based on priority of the functionality 
we can test as much as much as possible. 


e Even though 100% testing is not possible but I believe 100% customer 
satisfaction is certainly possible. 


Test Plan VS Test Strategy? e 


* ATest Plan is a formal document derived from requirement documents, describing in detail the scope of testing and the different 


activities performed in testing. Whereas, a test strategy is a high-level document describing the way testing will be carried out in an 
organization. 


a Test Plan Test Strategy 


A test plan is derived from Software Requirement 


Specification (SRS), describing in detail the scope of A test strategy is a high-level document describing 
testing and the different activities performed in the way testing is carried out. 
testing. 


A test strategy is normally for a complete 
A test plan is specific to a particular project. organization. Although it can be specified for a 
particular project as well. 


It describes the whole testing activities in detail - It describes the high-level test design techniques to 
the techniques used, schedule, resources etc. be used, environment specifications etc. 
It is prepared by test lead or test manager. It is generally prepared by the project manager. 


» 


Test Plan? 


* Test plan is a word document that described the testing scope 
-High level test cycle 
-Defect life cycle 
-Entrance Criteria (defines what all need to start the testing) 
-Exit Criteria (defines what the testing is finished) 


e If you don’t know where to start and where to finish then your goals are not 
clear. 


Test Case? 


* Test case describes the functionality and test steps. 


-Test Case ID 

-Step number 

-Description of the functionality 
-Expected result 

-Actual Result 


» 


When the testing starts? e 


* Testing starts from testing the requirements (not after the coding phase 
which seems like the most likely answer.) 


e We have to make sure the requirement is correct in first place. 
e With the wrong requirement it is impossible to build bug free application. 


Defect Life Cycle? 


e New 

* Assigned 
* Open 

* Fixed 

* Retested 
e Close 


» 


Epic, User stories & Tasks? e 


* User Stories:User Stories defines the actual business requirement. Generally 
created by Business owner 


e Task: To accomplish the business requirements development team create 
tasks 


* Epic: A group of related user stories is called an Epic 


What is testing hierarchy? A 


* Unit testing — Developers test each module or block of code during 
development. 


* Component Testing — Component is a standalone functionality that can 
work by itself. Ex. Amazon Buyer Functionality, Seller Functionality, Prime 
Video Functionality. 


* Integration Testing — Combine all of the Functionalities. When | integrate 
them, can | still use all of the functions? Make sure they all still work. 


* System Testing — EndtoEnd testing. Test everything from beginning to end. 


* Acceptance Testing — Hire a UAT (User Acceptance Testing) Team or Business 
Analyst can also do Acceptance Testing. 
After testing has been complete you have to get another team to do 
acceptance testing so they can confirm the QA teams testing was successful 
and have the product ready for the customer. 


Requirement Traceability Matrix (RTM) A 


e RTM is used to make sure that all test cases cover the requirement or not. It 
is like excel sheet. We can also say that RTM is an document which shows all 
the acceptance criteria and the user stories are covered by the Test Cases 
(Scenario) 


Defect 


* When expected result does not match actual result it is a defect. 


» 


What to do when you find a defect? e 


e If | find a defect, before report it | re-produce the bug that | need to make 
sure that is a valid defect. 


e If it is a small issue, | will go to the developer desk, and he can fix it right 
away. 


e |f it is a big issue, then | open my JIRA and log the defect. 


e° If lam not sure it is bug or not | will talk to SME (subject matter expert it 
means the person who knows the application better than anyone). 


If Developer says not a defect, what to do? @ 
* | always make sure that it is a real defect that's why | reproduce it. 


e | take a screenshots and give all the steps to reproduce the defect 


* Actually one of my biggest challenges that | faced in my current project is 
that... 


When will you Automate? A 


e If it is taking a lot of manual effort. | run at least once manually and after 
that | automate it. Automation is good for most repetitive functionality. 
-If the test cases are high priority test cases. 

-If the functionality is critical functionality. 

-If the test cases are too long and too difficult to execute. The regression 
test cases based on the priority. 

-We should automate as much as possible. 


When will you not Automate? 


e -If functionality keeps changing 
-If functionality is used only once during the entire project 
-Ad-Hoc test can not be automated. 


e Captcha can not be automated 


» 


Debugging vs testing? A 


e The main difference between debugging and testing is that debugging is 
typically conducted by a developer who also fixes errors during the 
debugging phase. Testing on the other hand, finds errors rather than fixes 
them. When a tester finds a bug, they usually report it so that a developer 
can fix it. 


Peer review? e 


* Peer reviews are reviews conducted among people that work on the same 
team. For example, a test case that was written by one QA engineer may be 
reviewed by a developer and/or another QA engineer. 


Who writes test plans and test cases? e 


* Test plans are typically written by the quality assurance lead while testers 
usually write test cases. 


A 


Bug severity vs bug priority 


* Bug Severity refers to the level of impact that the bug has on the application 
or system while Bug Priority refers to the level of urgency in the need for a 
fix. 

* Usually the severity is defined in terms of financial loss, damage to 
environment, company's reputation and loss of life. 


* Priority of a defect is related to how quickly a bug should be fixed and 
deployed to live servers. 


5 Levels of Severity 
1. Critical 

2. Major 

3. Moderate 

4. Minor 

5. Cosmetic 


System testing and integration testing? e 


* For system testing, the entire system as a whole is checked, 


* whereas for integration testing, the interaction between the individual 
modules are tested. 


Black box vs white box testing? A 


e White Box Testing has many names such as Glass Box, Clear Box, or 
Structural Testing. It requires the testers to gain code-level perspective, 
design cases to exploit code and find potential bugs. 


* Black Box Testing is a standard software testing approach which requires 
testers to assess the functionality of the software as per the business 
requirements. They treat the software as a black box and validate as per the 
end user point of view. It applies to all levels of software testing such as 
Unit, Integration, System or Acceptance Testing. 


Front End Testing and Back End testing? A 


* Front End Testing is performed on the Graphical User Interface (GUI), 
whereas Back End Testing involves databases testing. Front end consist of 
web site look where user can interact whereas in case of back end it is the 
database which is required to store the data. 


* When user enters data in GUI of the front end application, then this entered 
data is stored in the database. To save this data into the database we write 
SQL queries. 


Functional testing & non-functional testing e 


* Functional testing is a type of testing which verifies that each function of the software application 
operates in conformance with the requirement specification. 


* -Unit Testing 

* -System Testing 

* -Smoke Testing 

* -User Acceptance Testing 
* -Integration Testing 

* -Regression Testing 


* Non-functional testing is a type of testing to check non-functional aspects (performance, 
usability, reliability, etc.) of a software application. 


* -Performance Testing 
* -Stress Testing 

* -Load Testing 

* -Security Testing 


SDLC- STLC - AGILE ^ 


e STLC vs SDLC e Why do we need Agile? Waterfall and 
* Validation and verification ? Agile? 


* Requirement document? * Different roles in Scrum? 
q Se eee 


* Where is the requirement coming from? 
* The requirement is good or bad? 


* Describe a scrum team? 


e Scrum of scrums? 


* Agile * Burn-down and burn-up charts 
* Agile Framework? * Sprint? 
« Waterfall? * Product backlog & Sprint Backlog? 


* Agile methodology did you use in your * Velocit ota sprint and how it is 
previous projects ? ULSD ISIE 


* Relation between Agile and Scrum? What 
is Scrum? 


STLC vs SDLC e 


* STLC is part of SDLC. It can be said that STLC is a subset of the SDLC set. The 
complete Verification and Validation of software is done in SDLC, while STLC 
only does Validation of the system. 


SDLC (Software Development Life Cycle) STLC (Software Testing Life Cycle) 
1. Requirement gathering and analysis 1. Requirement / Design Analysis 
2. Design 2.Test Planning 
di e Test Plan 
3. Co INE e Test Estimation 
4. Testing e Test Schedule 
5. Deployment 3.Test Case Development (Designing) 
6. Maintenance e Test Cases / Test Scripts / Test Data 


e Requirements Traceability Matrix 
4.Test Environment Setup 
5.Test Execution 

e Test Results (Incremental) 

e Defect Reports 
6.Test Closure Activity (Reporting) 

e Test Results (Final) 

e Test Metrics 

e Test Closure Report 


Validation and verification ? ed 


* Validation is the process, whether we are building the right product 


* Verification is the process, to ensure that whether we are building the 
product right 


A 


Requirement document? 


e Requirements convey the expectation of users for the software or product. 
In other words, all the expected functionalities out of the application are 
documented in terms of “Requirements” and this document is called a 
Requirement document. It is also called an SRS document, which stands for 
System Requirement Specification Document. 

The SRS documented is prepared by the Business Analyst by taking all the 
requirements for the customer. 


Where is the requirement coming from? ed 


e Customers give requirements for the application Talk to the End-users the 
person that will be using this application the most 


e Talk to Partners 


e Talk to Domain Experts — coders and developers that have already build this 
application similar before or someone that is an expert the type of product 
being built 


e Industry Analysts and Information about competitors 


» 


The requirement is good or bad? 


* Requirement must be (SMART) 
Specific User should be able to login. Authorized 


* user with valid username and password should be able to login 
Measurable User should able to login very fast (in 2 second after clicking 
login button). 


e Attainable 
Realistic 
Testable 


Agile 


* Agile is flexible methodology using for Software Development. 
* You can go back. 
e |t keeps on changing. 


* Changing is always welcome. 


» 


Agile Framework? A 


* Role : PO, SM, Team 


* Ceremonies : Sprint Planning, Daily Scrum, Sprint Review, Sprint Retro, 
Grooming Session 


* Artifacts : Product backlog, Sprint backlog, Burnout chart 


Waterfall? ed 


e Waterfall methodology is the sequential method using for Software 
Development. 


* You can not go back and have to finish the phase before you move on. 


Agile methodology did you use in your previous e 


projects ? 


* | have heard Extreme programming(XP) , Kanban and Scrum. 
* But | have only worked with scrum only. 


Relation between Agile and Scrum? What is e 
Scrum? 


* Agile is the software development methodology that focuses on customer 
satisfaction by delivery shippable software frequently. 


e Scrum is one of the many approaches to implement Agile. 
e Scrum is an Agile framework. 


e Scrum is suitable for certain type of projects where there are rapidly 
changing requirements. 


* |n simple words, Agile is the practice and scrum is the process to following 
this practice. 


Why do we need Agile? Waterfall and Agile?ft 


* Because waterfall methodologies have following disadvantage; E 
Requirement can not be change or hard to change once document is signed. 


* |n waterfall before eos the one phase you can’t move to the next phase. 
For example, before coding phase is completed testing can not be started. 


° T can't see what they are going to get until very late stage in development 
ife cycle. 
It takes longer time to go to the production. By the time product goes to the 
market it might be outdated already. 


* Agile has following advantages: 
The change is welcomed. For example after the sprint demo if client does not like 
something we can take their feedback and improve the product. Requirement 
change is OK. 
Since it is iterative development process, the development team can developed 
ages of functionality, get feedback and improve next iteration. So the product will 
e continuously improve. 


Different roles in Scrum? e 


* Product owner is actually the stakeholder of the project. He represents the 
project requirements before the team.He is responsible to have a vision of 
what to build and convey his detailed vision to the team. He is the starting 
point of an agile scrum software development project. 


* Scrum team is formed by the collective contribution of individuals who 
perform for the accomplishment of a particular project. The team is bound 
to work for the timely delivery of the requested product. 


* Scrum master — Scrum master is the leader and the coach for the scrum 
team who checks whether the scrum team is executing committed tasks 
properly. He is also responsible to increase the efficiency and productivity of 
the team so that they can achieve the sprint goal effectively. 


Describe a scrum team? e 


* For me the team is a group of people who are sharing the same goal, 
moving to the same direction , who trust each other and who will effectively 
communicate and collaborate with each other to build great product. There 
should be no star individual but a star team. 


Scrum of scrums? e 


* |n case, there are multiple teams involved in the project, scrum of scrums is 
used to scale the daily stand-up meeting. 


e |t supports agile teams to collaborate and coordinate their work with other 
teams. 


Burn-down and burn-up charts 


* To track the progress of an ongoing project, these charts are used. 
* Burn-up charts indicate the work that has been completed while 


* Burn-down chart shows the amount of remaining work in a project. 


» 


Sprint? A 


e In Scrum, the project is divided into Sprints. 


e Each Sprint has a specified timeline (2 weeks to 1 month). This timeline will 
be agreed by a Scrum Team during the Sprint Planning Meeting. Here, User 
Stories are split into different modules. The end result of every Sprint should 
be a potentially shippable product. 


Product backlog & Sprint Backlog? A 


e Product backlog is maintained by the project owner which contains every 
feature and requirement of the product. 


* Sprint backlog can be treated as subset of product backlog which contains 
features and requirements related to that particular sprint only. 


Velocity of a sprint and how it is measured? e 


* Velocity is one of the planning tool used to estimate the speed of the work 
and time of completion of the project. 


* The calculation of velocity is done by reviewing the work team has 
successfully completed during earlier sprints; 


* for example, if the team completed 5 stories during a two-week sprint and 
each story was worth 3 story points, then the team's velocity is 15 story 
points per sprint. 


BEHAVIORAL QUESTIONS si 


* Biggest Accomplishment? * What do you do if | hire you? 
* Why did you apply for this position? * How long are you planning to stay? 
* Where do you see yourself 5 years from * Can you work under pressure? 
? l 
OA e What do you like the most about testing? 
è ; 2 ; 
Why should we hire you: * What to do in case of you have too much 
e Weakness? work and you can... 
* Strength? * Do you have any question for us? 
* Challenge you faced during your last 
project? 


* How do you handle stress? Or Conflict? 
* Can you start tomorrow? 


Biggest Accomplishment? @é 


* | would say is establishing a great trustworthy relationship within the team. 
If you are asking for technical: When | joined my last project, the application 
had very less "id" so | had to spend hours to locate one WebPage elements 
in my POM project so | communicated with developers and other team 
members and all together we come up with the solution which | got the 
access to put id in the application by myself. 

That was great for me it saved my and others time. So instead of spending 
time to locating elements | spend my time to more creating automation test 
scripts and executing them. 


Why did you apply for this position? @é 


e After looking at the job description, | think it matches my day-to-day activity 
and my experience. 


* | was confident with the job description that’s why | applied. 


e Also, | have done some research on the company and | am really excited 
about the company's product and services like... 


Where do you see yourself 5 years from nov 


e | want to learn as much as possible to be more technical. | would like to see 
myself SDET. | want to be technically very competitive person 5 years from 
now. 


A 


Why should we hire you? 


e | think you should hire the candidate that has the best qualifications for this 
position. Since | don't know the other candidates, | can represent only 
myself. | think my experience and technical expertise will bring a lot of 
values and benefits to the company and the project. | think that's why you 
should hire me. 


Weakness? @é 


* Well, | think my weakness is that whenever | am given some responsibilities 
and there is a deadline for it, | work day and night, sometimes 7 days a 
week. This is bad for my family life, the reality is | can not sleep unless | am 
done with my assignments. 


Strength? 1) 


* Well, | am very detail oriented person. | have the sense of urgency. | can 
prioritize my job according to the deadline. | am very much dedicated 
towards my job. | am honest. | have the skills and expertise in QA process. 
These are some of my strengths. 


Challenge you faced during your last project? e 


° ms one of the biggest challenges that I faced with in my current project is 
that... 


e ... everytime | found a bug, the developer disagreed to accept it and most of the 
time we had to ask BA for clarification. Then | realize the requirement itself was 
not specific enough, so | understood it differently than the developer. In the Sprint 
Retro, | said we should pen more time on requirement clarification because you 
know that is the key to the ps success. We did so and this issue was solved. 
Work on result more. | think, the most important problem is misunderstanding 
and the lack of communication in the business life. If we come together as a group 
and discuss it, there is nothing we cannot solve. I'm really grateful and blessed to 
have been in the team that | was in, because we were able to collaborate and 
come together to solve the problem. 


e The challenge | have faced is locating dynamic elements by retrieving the right 
Miu: ERE One of my recent challenge is that another coworker who is also QA 
ad to leave. 


How do you handle stress? Or Conflict? A 


e Nothing is personal. Everyone thinks company’s benefits so | would like to 
explain my concern and his/her explanation makes sense for me. Of course, 
| can do the things which is most helpful to my company. So, I try to 
communicate with his/her and | would try to understand the concern. 
Because everyone have the same goal and wants to get job done 
successfully.Aiso in scrum environment we working as a team . | always 
maintain good communication and relationship with my colleagues. So they 
trust me and they can communicate with me very easily. . . | always avoid 
miscommunication and my team believe me every time. 


Can you start tomorrow? e 


* My team won't be happy with me if | leave tomorrow, and | don't think it is 
professional and | have never done that before. | have to transfer the 
automation framework knowledge to other team members before | leave. 


A 


What do you do if | hire you? 


* In first week, you know, | will get done all the paper works, getting the 
machines and necessary access to the project, databases etc.Then | will have 
to learn the company culture. | have to learn also more about my projects 
and my teammates. | think, understanding what the project is doing, it is 
very important if | want to be more productive. 


how long are you planning to stay? e 


* As long as there is a project to work, | am willing to stay as long as possible. 


Can you work under pressure? e 


e | don’t remember any project that | worked had no pressure. Pressure is 
good thing sometimes. It forces you to work harder and smarter. 


What do you like the most about testing? e 


* Testing is fun job for me because you are very important person to the client 
and end users. | love testing because as end user | want to buy better 
product that is piece of art and defect free. Also, | am helping others to 
make sure their product has top quality. 


What to do in case of you have too much work e 
and you can not finish for the deadline? 


* When developers don't deploy their code on time, our tester team don't 
have enough time for completion. And the upper management keeps asking 
for us for completion. - Some of my team members simply focuses on task 
completion and not on the test coverage and quality of work. - So, at the 
Sprint Grooming Meeting, | suggested that we should work very closely with 
the developer and make sure that we are communicating on daily base. And 
also, the developers prioritize the important tasks and work on them first. 
Any scenarios left, would be pushed to the next sprint since it is not as 
important as the other ones. - Lastly, | try to prioritize my work and follow 
my test lead and manager whatever they see is more important | start with 
that. 


Do you have any question for us? e 


* it's important to me that | continually improve and try to achieve excellence 
in my position and the best way to do this is to continually learn. I'm always 
trying to learn new things or learn old things better. 


* Do you provide trainings, seminars or anything to support the education of 
your employees? 


e What are the next steps in the interview process? 


JAVA 


String - StringBuilder- StringBuffer-Mutable-Immutable 


Final vs Finalize vs Finally? 


= xceptions 


Access Modifiers in Java 


i» 


C) 


ollection 


m 


this & Super kewords [this. - this() - Super. - Super uals() vs == in Java 


STATIC Keywords (variable, methods, blocks) 


Differences in 
Pass by value or Pass by reference 


Break vs Continue 
Java 7 vs Java 8 
Lambda Expression in Java 


Thread-safe or Synchronized 


JAVA 


Multithreading in Java 
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JDK, JRE and JVM e 


JVM: Java Virtual machine(JVM) is an abstract machine. It doesn't physically exist. Whatever Java program we want to run, 
goes into JVM. And JVM is responsible for loading, verifying and executing the java program. JVM is responsible for converting 
the byte code to the machine-specific code. 


JRE: JRE stands for "Java Runtime Environment". It physically exists. The Java Runtime Environment provides the minimum 
requirements such as libraries and Class Loader for executing a Java application on JVM. It consists of the Java Virtual Machine 
(JVM), core classes, and supporting files. JRE = JVM + Library Classes 


JDK: The Java Development Kit (JDK) is a software development environment used for developing Java applications. JDK - JRE 
+ Development tools. It includes: 


2Java Virtual Machine, 

2Java Runtime Environment, 
2| oader, 

"Java compiler, 
"Documentation generator 
"Archiver (jar), 


"Other tools needed in Java development. 
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ublic static void main (String[] aras) in Java 4 


- public: 
public is an access modifies which is used to specify who can access this method. 
Public means that this method will be accessible by any Class. 
- static: 
It is a keyword in java which identifies it is class bases i.e 
it can be accessed without creating the instance of a class 
- void: 
itis the return type of the method void defines the method which will not return any value 
- main: 
itis the name of the method which is searched by JVM as a starting point for an application with a 
particular signature only. It is the method where the main executions occurs 
- String args: 


it is the parameter passed to the main method 
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String - StringBuilder - StringBuffer- Mutable- Immutable N 


* Strings are object representation of character sequences 


* Strings pose ERR The original object value cannot be changed. String variables are 
stored in ' d 


- There is two ways to make a String object: using new keyword or by giving the literal value 


- Literal Strings will be stored in the String pool 
* MUTABLE Strings made with new keyword will be stored in the heap memory like other objects 


* StringBuilder and StringBuffer are MUTABLE String objects. If the values are changed then the new 
value replaces the older value. 


* StringBuffer is synchronized and therefore it is slower than StringBuilder. 


Java Heap 


STRING METHODS | 
———————————————— Pam — —' String s1 = "Cat"; "Cat" 
CNET: a id 
String s3 = new String("Cat"); 
indexf] toLowerCasel toUpperCase) replace) — 
substrind) trim() startsWith) cf dcWlth $1 == $3; //false 
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String Pool and Heap in Java 4 


* String Pool in java is a pool of Strings stored in Java Heap Memory. We know that String is a special 
class in java and we can create String objects using a new operator as well as providing values in 
double-quotes. 


e String Pool is possible only because String is immutable in Java and its implementation of String 
interning concept. String pool helps in saving a lot of space for Java Runtime although it takes more 
time to create the String. 


* When we use double quotes to create a String, it first looks for String with the same value in the 
String pool, if found it just returns the reference else it creates a new String in the pool and then 


returns the reference. package com.journaldev.util; 
Java Heap public class StringPool { 
ike se 
* Java String Pool example 
String s1 = "Cat"; * @param args 
* 
public static void main( 
Strings si. — Gates; 
String s2 = "Cat"; String s2 = "Cat"; 


String s3 new String("Cat"); 


System- out- printlnG si) == S2 *(s41-22s2))/ 


System- out- PreiInNneinC esi == 53 (ST =S3)); 


String $3 = new String("Cat"); 


$1 == s2; //true i 


Output of the above program is: 


$1 == 53; //false 


S1 == s2 :true 
si == s3 :false 75/ 


Classes & Objects 


Classes act as a blueprint of objects, which are real world representations of objects, in 
programming 


Each object is referred to as an instance of the class it is created from. 
Object is a member or instance of a class 
Class is declared using class keyword, Object is created through new keyword mainly. 
Everything in java is written in a .java file which will be compiled to a .class file 
e Note: The java file and class file should have the same name 
Objects are created by using new keyword in the following format: 


eClassName referenceName - new ClassName() 


» 
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this & Super Keywords [this. - this() - Super. - Super 


this is used to call the current class members (variables and methods). 
- this.variableName in the sameClass 
- this.methodName in the sameClass 
- this can be used anywhere in a class, except static block or static method 


this() is used to call a constructor in the same/current class 
- If this() is called in an overloaded constructor, it must be the first line 


Super is used to call the parent class members (variables and methods) 
- Super.variableName from the SuperClass 
- Super.methodName from the SuperClass 
- Super. can be used anywhere in a class, except static block or static method 


Super() is used to call the constructor from the parent class 
- Super() must be the first statement in the constructor. 


» 
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Class members - METHODS 4 


e Methods are functions which perform certain actions 
e There is two types of methods: void and return 
e void: Methods that perform some action without returning any value 
e return: Methods that will perform an action and return a single value or object back 
e Methods can be invoked by using an object following by the dot operator and method name with 
parentheses at the end B. 


String name 
age 


O1 
System.out.println(age) 


(String[l args 
Person james - Person() 


james.printAge() 


eVal - james.getAge() 
System.out.println(ageVal) 
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Class members - METHODS 


e Methods can have parameters which act as required information to execute a method 
e Any parameters declared in a method act as local variables for that method 


e Multiple parameters can be given by separating each variable with a comma 


public class 


int age; 


void (int age) { 


this.age = age; 


A 
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STATIC Keyword (Static variable, Static Method) 4 


you can access them without creating an 
object, just by using a classname. 


- Static members belong to class itself, they are also called 
class members. 


- We can call static members by using class name or object 
- But Static methods can not call Non Static members 
- What can be static? Variables, method, block, inner class 
can be Static. 
is also called «shared variable», it will 
have only one copy of it. Every object of the class will 
share the value of it. It is called by ClassName. 
a method that can be called by 
classname, without creating an object 
-» objects can also call static methods. 
-» Only static variables can be in a static method 
-» static methods can only access other static variables or 
methods. 
-» static methods cannot call/use instance variables or 
non-static methods. But non-static method can call a 


static method. 


code in static block executes only ONCE 
and BEFORE EVERYTHING ELSE, whenever the class is 
used. 


import static java. lang.Math.x; 
public class House 1 
static int numberOfHouses; 
static int getHouse() 1 
return max(10,20); 
} 
static { 


numberOfHouses = getHouse(); 


} 


public static void main(String[] args) { 
System.out.println(House.numberOfHouses) ; 


} 
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PN 
Local, Instance and Static variables fà 


e Local variable is typically used inside a method, declared with the static keyword in a class, but 
constructor, or a block and has only local scope. outside a method. Static variables are also called 
The best benefit of having a local variable is that shared variable, it will have only one copy of it. 


other methods in the class won't be even aware of Every object of the class will share the value of it. 
that variable. 


* Instance variable is a variable which is declared 
ə public class variablegxamele< 


within a class, but outside a method. Instance tnt mvvaran gt 

Variable belongs to the OBJECT. Can be called by oo D 

object name. Every object of that class will create ——— 

it’s own copy of the variable while using it. Thus, « — Varabistxampis obj = new varableExamoie; MENEE 

any changes made to the variable won't reflect in sytem open Value of instance variable manae: “m/v; IRR 


any other instances of that class and will be bound = ons cuim can cited of static variable data: "+VariableExample.data) ;//instance 


to that pa rticula r insta nce on ly. ° System.out.printin("Value of local variable a: "+a); 
e 

Numbers default to 0, Objects default to null, Booleans default to false L3Ó 

Output: 


ə Value of instance variable myVariable: 0 


* Static (class) variable belongs to the CLASS, can be eee 
called through class name. Static variables are + _ Value of local variable a: 100 


Class members — INSTANCE VARIABLES 4 


e |nstance variables are the data items inside of classes but outside of a method 
e These variables have datatypes as any other variable 
e Every instance, which refers to each object, created from a class will have those instance variables 
e These variables have default values 
e Numbers default to 0, Objects default to null, Booleans default to false 
e Objects can refer to their instance variables with the dot " . " operator 


public class Person { 


String name; 
int age; 


public static void main(String[] args) { 
Person joe - new Person(); 
joe.name = 4 
joe.age = - 


System.out.println(joe.name); 
System. out.println(joe.age) ; 
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OVERLOADING Method e 


e Overloading mean having multiple methods with the same method name but different parameters in 
the same class. This allows us to have more than one method with same name. 


e Method overloading is achieved by having method with the same name that have a different number 
of parameters or have a different number of parameters. In short, the method signature must be 
different to overload a method 


e |t doesn't matter, Return type can be same or different in method overloading. 
e |t doesn't matter, Access Modifier can be same or different in method overloading. 


e When a method is overloaded the arguments will match to the best method that matches those 
parameter types and execute that method. Methods cannot be ambiguous with these parameters 


Example: sort method of Arrays class 
Arrays.sort(int[] arr) 
Arrays.sort(String[] arr) 
Main method can be overloaded if we pass different parameters. 


Method overloading improves the reusability and readability. It's easy to remember (one method name 
instead of remembering multiple method names) 
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Overloading vs Overriding 


Method Overloading 


Method Overriding 


Same method name with different 
parameters 


Method overloading is achieved in the same 
class 


Return type can be same or different 


Access modifier can be same or different 


Private and final methods can be overloaded 


Same method name with same parameters 


Method Overriding occurs in two classes that 
have IS-A relationship 


Return type must be same or covariant type 


Access modifier must be same or more visible 


Private and final methods CANNOT be 
overridden 
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Constructor 4 


e Constructors are the special methods without any return type. Constructors have the same 
name with the className 


e Constructors are special methods, which are called whenever the new keyword is used to 
create an object of a class 


e By default every class always has a default constructor with no parameters. This default 
constructor is no longer there if a constructor is created manually 


e Constructors usually act to initialize instance variables or perform actions that need to be 


taken whenever an object of a class is created. { 
species; 


e Like methods, constructors can also be overloaded. size; 


height; 


The same rules apply. This is done by providing 


.Species species; 


a constructor with with a different parameters 
( 


e this() can be used to call the overloaded e 


constructors with other parameters f 


(species, size); 
. height height; 


Constructor (detail to know. Do not talk about this) 


. : . : public class House { 
In this example the first constructor will be invoked 


Because the constructor call does not have parameters, string EN 


but as Shown it is possible to also overload constructors 


public House (){ 
this.address = 


House -> Class name ; 


houseOne -» reference name of object 


new House() -» used to invoke constructor 


public (String address) { 
this.address = address; 


} 


public static void main(String[] args) { 


= new House(); 
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Constructor — Rules for Constructor chaning 4 


1. Any constructor call must be call from another constructor 
2. In order to call an overloaded constructor, MUST use this() keyword 
this(): can only be used in a constructor calling another constructor (DO NOT USE NAME OF CONSTRUCTOR) 
3. Constructor call MUST be at FIRST line of a constructor. If we call at later step ==> Compiler error 
4. A Constructor can call ONLY ONE Constructor. If we call twice ==> Compiler error 
5. A Constructor can NOT call ITSELF. If it calls itself ==> Compiler error 


6. A Constructor can NOT contain itself ==> Meaning if a constructor called another, the latter cannot 
call the first (because of rule 5) 


At the Interview 
Do not read this page. This is detail to know about the constructor 
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Constructor vs Method? e 


Constructor is a special method in the class that is executed whenever object is created. Doesn't have a 
return type and constructor's name must be same as the class name. 


Constructor is called automatically when a new object is created. 

Constructor is invoked implicitly. 

The Java compiler provides a default constructor if we don't have any constructor. 
Constructors are not inherited by child classes 

Method: Collection of statements that are grouped together to perform an operation. 
Method have a return and the method's name may or not be same as the class name. 
Method is invoked explicitly. 


Method is not provided by compiler in any case. Methods are inherited by child classes. 


» 


Final vs Finalize vs Finally? 


* finalis a keyword and used to apply restrictions on class, method and variable. 
- final is a keyword 
- final class cannot be inherited 
- final method cannot be overridden 
- final variable value cannot be changed. 
* finally is a block and used to place important code, it will be executed whether exception is handled or not. 
- finally is a block which is used for exception handling along with try and catch blocks 
* finalize is a method and used to perform clean up processing before object is garbage collected. 
- finalize() method is protected method of java.lang.object class 
- itis inherited to every class you create in java 


- finalize() method is used to perform some clean up operations on an object before it is removed from 
memory by the garbage collector method. [sc.garbage() ] 


Access Modifier 


» 


e Access modifiers can be applied to variables, classes, methods, constructors 
Public — visible to the the whole project 
Private — visible only within the same class 


Protected — visible only in the same package or sub classes in other packages (inheritance) 
Default — visible only in the same package. If no modifier is given this is the default modifier 


Public » Protected » Default » Private 
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equals() vs == in Java 


* Equals() method is used to compare the values of the objects. 


e “==” or equality operator in Java is a binary operator provided by Java 
programming language and used to compare primitives and objects. It 
compare the references and also values of the objects. 


» 


Java pass by value or pass by reference? e 


- Java is a "pass-by-value" language. This means that a copy of the variable is made and the 
method receives that copy. Assignments made in the method do not affect the caller. 


Passing by value means that the value of the function parameter is copied into another 
location of your memory, and when accessing or modifying the variable within your function, 
only the copy is accessed/modified and the original value is left untouched. Passing by value 
is how your values are passed on most of the time. 


Passing by reference means that the memory address of the variable (a pointer to the 
memory location) is passed to the function. This is unlike passing by value, where the value of 
a variable is passed on. In the examples, the memory address of myAge is 106. When passing 
myAge to the function increaseAgeByRef, the variable used within the function (age in this 
example) still points to the same memory address as the original variable myAge (Hint: the & 
symbol in front of the function parameter is used in many programming languages to get the 
reference/pointer of a variable). 


Break vs Continue 


* break leaves a loop, continue jumps to the next iteration. 


» 


A 


Java / vs Java 8 


JAVA 7 JAVA 8 


String in Switch statement Lambda Expression 
Multiple Exceptions Handling Pipelines and Streams 


date and time in API 


Java 8 interface changes 


Static Method, Default Method which are used in 
Interface too 


Lambda Expression in Java e 


* Lambda Expressions were added in Java 8. A lambda expression is a short block of code 
which takes in parameters and returns a value. Lambda expressions are similar to 
methods, but they do not need a name and they can be implemented right in the body of 
a method. 


* Example: Use a lambda expression in the ArrayList's forEach() method * Example: Use Java's Consumer interface to store a lambda 
to print every item in the list: expression in a variable: 
import java.util.ArrayList; 


import java.util.ArrayList; 
import java.util.function.Consumer; 


public class MyClass { 
public static void main(String[] args) ! public class MyClass 

ArrayList«Integer» numbers = new ArrayList<Integer>(); public static void main(String[] args) | 

numbers . add (5) ; ArrayList«Integer» numbers - new ArrayList«Integer»() 
l numbers.add(5); 

numbers. add(9); numbers .add(9); 

numbers . add(8); numbers .add(8); 

numbers .add(1); numbers. add(1) ; 


numbers.forEach( (n) -> ( System.out.println(n); ) ); Consumer«Integer» method = (n) -> ( System.out.println(n); } 
numbers.forEach( method ) 


What is Thread-safe or Synchronized? e 


e Thread safety is very important, and it is the process to make our program safe to use in 
multi-threaded environment, there are different ways through which we can make our 
program thread safe. 


° Synchronization is the easiest and most widely used tool for thread safety. 
e JVM guarantees that synchronized code will be executed by only one thread at a time. 


e JAVA keyword synchronized is used to create synchronized code and internally it uses 
locks on Object or Class to make sure only one thread is executing the synchronized code. 


e | mean Java synchronization works on locking and unlocking of the resource, so no 
thread enters into synchronized code. 


e We can use synchronized keyword in two ways, one is to make a complete method 
synchronized and other way is to create synchronized block. 


Multithreading in Java e 


Multithreading is a Java feature that allows concurrent execution of two or more parts of 
a program for maximum utilization of CPU. Each part of such program is called a thread. 


So, threads are light-weight processes within a process. Threads can be created by using 
two mechanisms : 
1. Extending the 


1.Inorder to Thread creation by extending the Thread class: We create a class that extends the java.lang.Thread class. This class overrides the 
run() method available in the Thread class. A thread begins its life inside run() method. We create an object of our new class and 
call start() method to start the execution of a thread. Start() invokes the run() method on the Thread object. 


Detail: 


2.In Order to Thread creation by implementing the Runnable Interface: We create a new class which implements java.lang. 
Runnable interface and override run() method. Then we instantiate a Thread object and call start() method on this object. 


OOP PRINCIPLES 


OOP Concept 
ENCAPCULATION 


INHERITANCE 


Singel, Multi Level and Hierarchical 
INHERITANCE 


IS- A & HAS-A (Composition) Relationship 
CONSTRUCTOR and Inheritance 

STATIC MEMBERS and INHERITANCE 
OVERRIDING Methods 

OVERRIDING Methods Rules 

Super keyword 

THIS Vve SURER 

THIS() vs SUPER() 


e 
ABSTRACTION 
= ABSTRACT CLASS 
= INTERFACE 
- Differences: Abastract Class VS Interface 
POLYMORPHISM 


- Static - Dynamic Polymorphism 
- REFERENCE CASTING - Polymorphism 


Differences: Abastract Class VS Interface 
Differences: 
Differences: 
Differences: 
Differences: 
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OOP - Object Oriented Programming Concept 4 


Encapsulation: 
We can hide direct access to data by using private key and we can access private data by using 
getter and setter method. 
Inheritance: 
It is used to define the relationship between two classes. When a child class acquires all properties 
and behaviors of parent class known as inheritance. Child class can reuse all the codes written in 
parent class. It provides the code reusability. 
Abstraction: 
It is a process of hiding implementation details and showing only functionality to the user. 
Abstraction lets you focus on what the object does instead of how it does it. 
Polymorphism: 
It is an ability of object to behave in multiple form. The most common use of polymorphism is Java, 
when a parent class reference type of variable is used to refer to a child class object. 

E.g.: WebDriver driver = new ChromebDriver(); 


We use method overloading and overriding to achieve Polymorphism. 
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ENCAPCULATION 4 


e Encapsulation allows the programmer to hide and restrict access to data. More specifically encapsulation will 


allow an object to hide its variables and methods from being accessed outside of a class. Jo achieve 
encapsulation: 

1) Declare the variables with private access modifier 

2) Create public getters and setters that allow access to those variables 
* Wecan provide only getter in a class to make the class immutable. ( ) 


e Wecan provide only setter in a class to make the class attribute 
public class 1 


private String name; : z : : : 
private int aces public static void main(String[] args) { 


mu Ot Person p1 = new Person(); 
return age; 
E 


p1.setName( ); 


public void (int age) (1 p1.setAge(27); 


this.age = age; 
} 
System. out.println( + pl.getName() + 


ud ae \n + p1.getAge()); 


} 


public void (String name) { 
this.name = name; 


} 
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ENCAPCULATION in my project e 


In my project | created multiple POJO/BEAN classes in order to manage test data and actual 
data. | take JSON from API response and convert to object of my POJO class. All the variables 
are private with getters and setter. Also in order to store credentials or sensitive data in my 
framework | have use encapsulation, configuration reader also known as property file or excel 
sheet to hide data from the outside. | use Apache POI if the data store in Excel in order to 
extract/read and modify data. 
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INHERITANCE e 


e Inheritance allows one class to inherit content from another class (fields and methods), or in 
other words, allows a class to be a copy of another class. It allows code reusability. 


e Super class (also known as parent or base class): is the class where the fields and methods 
that are being inherited or passed on 


e Sub class (also known as the child or derived class): is the class getting the inherited fields 
and methods 


e |n order to use inheritance in java we use extends keyword 

e One class cannot extend more than one super class. Every class in java inherits Object class 
What is inherited in Java: 

e All public and protected variables and methods 

e All default variables and methods if the super and sub classes are in the same package 

What is NOT inherited in Java: 

e Constructors are not inherited 


e Any private variables or methods are not inherited 
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Singel, Multi Level and Hierarchical INHERITANCE 


public 
} 


public B extends A1 B extends A 


B extends Af 


C extends Bi COCOA TE TA 


Single inheritance 


Multi-level inheritance D extends A 


Hierarchical inheritance 
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IS- A & HAS-A (Composition) Relationship 4 


e |S-A relationship can be used to describe the relationship between classes that are using 
inheritance 


IS-A: 

- German Shepherd IS-A Dog 

- Dog IS-A Animal 

- German Shepherd IS-A Animal 
HAS-A: 


- Cas HAS-A engine 
- Dog HAS-A tail 
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CONSTRUCTORS and INHERITANCE e 


e The super class constructor always executed before the sub class constructor 

e |t is possible to call the super class’ constructor using keyword Super() 

e The default no parameter constructor automatically invokes its super class constructor 
e Rules: 


- If this super constructor is called explicitly it must be the first line in the sub class 
constructor: super() 


- The parameters must match with parent constructor. If parent class has only 
constructors with 


parameters, then an explicit call must be made matching those parameters 
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STATIC MEMBERS and INHERITANCE e 
e |f the access modifier allows inheritance, static members will also be inherited 


e Static variables will be shared for all objects related to that class. All the object from the 
parent to the child 


e Static methods can be called using the parent class name or sub class name 
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OVERRIDING Methods e 


e After inheriting a method from the parent class, the child class can change the action. So we 
are able to keep the same method, but change the implementation to better match the child 
class’ needs. In method Overriding; 


1. There must be is-a relationship (inheritance) between the classes. 
2. The method must have the same name AND same parameters as in the parent class 
3. Access modifier needs to be same or more visible 


4. Return type must be same or covariant type (same class type or sub class type) 


e We can use the (2Override annotation before the method to tell the compiler we are 
overriding a method. It will help ensure the method is overridden correctly. 

e Ex: toString() method 

* KK 

e Unlike methods, it is not possible to override a variable, but if it is possible to hide them. Variable hiding occurs 
when a variable is declared with the same name as a variable from the super class 
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OVERRIDING Methods RULES e 


1. There must be is-a relationship (inheritance) 
2. The method must have the same name AND same parameters as in the parent class 
3. Access modifier: Needs to be same or more visible 
4. Return type: 
e must be same or 
e covariant type (same class type or sub class type) 


***Notes: 
We cannot override static methods. If you try, they will become hidden 


e A hidden method occurs when a child class defines a static method with the same name and signature as a 
static method defined in a parent class. 


e Method hiding is similar but not the same as method overriding. 


e The rules for overriding a method are the to hide a method, but in addition, the method must stay static. 
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Super keyword 4 


The Super keyword in java is a reference variable that is used to refer to parent class objects in 
inheritance 


e Super with variables (Super.variable) 
e Super with methods (Super.method) 
e Super with constructors (Super() ) 
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THIS vs SUPER e 


e Super is used to access/call the parent class members (variables and methods) 

e this is used to call the current class members (variables and methods). 

e Can be used when parameter local variables have the same name is instance variables 
e Both can be used anywhere in a class, except static block or static method 
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THIS() vs SUPER() e 


e this() is used to call an overloaded constructor in the same class. 


e super() is used to call the constructor from the parent class 


e Both this() and super() must be the first statement in the constructor. This result in one 
constructor calling another constructor. 
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INHERITANCE in my project e 


In my framework I have a TestBase class where I store all my reusable code and methods. My 
test execution classes, and elements classes will extend the TestBase in order to reuse the 
code. 


My framework follow POM and some pages have similar actions, so | can easily use those 
similar actions and fields by inheriting some a common class. 


What is overriding? 


Overriding means changing the implementation of a method that is coming via inheritance from a 
super class 


Example: get method 
WebDriver driver = new ChromeDriver(); 
driver.get("URL") ==> opens the url from chrome 
WebDriver driver = new FireFoxDriver(); 


driver.get("URL") ==> opens the url from Firefox 
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ABSTRACTION 


e Abstraction means IMPLEMENTATION HIDING. 


e Abstraction deal with what method can do instead of how method can do! 


» 


e |n java, abstraction is achieved via abstract class or interface 
e Abstraction cannot exist without inheritance 
e Abstraction is achieved by two way Abstract Class and Interface 
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Abastract Class VS Interface 


A 


Abstract Classes can have abstract and non-abstract 
methods. 


An abstract class can have instance variables. 
An abstract class can have the constructor. 


A class can extend one abstract class. 


The abstract keyword is used to declare an abstract class. 


An abstract class can be extended using extend keyword 


An abstract class can extend another Java class and 
implement multiple Java interfaces. 


A Java abstract class can have class members like private, 
protected, public. 


Example: 
public abstract class Shape{ 
public abstract void draw(); 


j 


The interface has only abstract methods and with Java-8 
static and default methods. 


An interface cannot have instance variables. 
The interface CANNOT have the constructor. 
A class can implement multiple interfaces. 


The interface keyword is used to declare an interface. 


An interface class can be implemented using 
keyword implements 


An interface can extend another Java interface only. 


Members of a Java interface are public by default. 


Example: 
public interface Drawable{ 
void draw(); 
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ABSTRACT CLASS RULES e 


e To create an abstract class: add keyword abstract before the class declaration 
e An abstract class cannot be instantiated — An object can never be created from that class 


e An abstract class allows creation of abstract methods, which are declaration of method signatures 
without any implementation. In other words, methods without a body. 


e The class which inherits the abstract class is called the concrete class. The concrete class must 
implement all abstract methods declared from the abstract class 


e Variables act following regular inheritance rules 


Abstract class called Student > 
Abstract method named attendllass() > 


Concrete class named LocalStudent > 


Implementation of abstract method 


attend lass > 


ABSTRACT CLASS RULES 4 


e Abstract classes can not be instantiated 

e Abstract classes may be defined with any number of abstract and non-abstract methods, including 
none 

e Abstract classes can not be private or final. A class can extend only one abstract class. 

e An abstract class that extends another abstract class inherits all its abstract methods as its own 
abstract methods 


e The first concrete class that extends an abstract class must provide an implementation for all the 
inherited abstract methods: 


e It's possible for an abstract class to inherit another 
abstract dass. In this case implementation of the abstract 
methods are not required 


e |n this case the sub abstract class is not a concrete class, 
but as soon as a concrete class inherits all the properties 
of that abstract class it must implement all abstract 
methods trom all super classes 


ABSTRACT CLASS RULES e 


e Abstract methods can only be defined in abstract classes or interfaces 


e Abstract methods can not be declared private or final (public abstract void dog(); or void 
dog();) 


e Abstract methods can not provide a method body/implementation in the abstract class or 
interface it is declared 


e Implementing an abstract method in a subclass follows the same rules for overriding a 
method. 


e Do abstract classes have a constructor? 


-> Yes, the class is still inheriting the Object class and has a default constructor (but 
Interface cannot have constructor) 


e Can an abstract class have only non-abstract methods? 
-» Yes, an abstract class doesn't need to have any abstract methods. 


e |f the abstract class doesn't have any abstract methods, can you instantiate? 


-» No, objects of an abstract classes can never be made Continue d 
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ABSTRACT CLASS RULES 4 


e Can you add instance or static variables into abstract class? 


-» Yes (But you cannot add into Interface. Interface can only have constant variable which is static 
final variable) 


e Can you add initializer or static blocks into Abstract class? 
-» Yes 
e What access modifiers can abstract methods be? 
-» They can have any access modifier except private 
e Can an abstract method be static? 
-» No, abstract methods are meant to overridden, and only the instance methods can be override 
e Can a method be abstract and final? 


-» No, we cannot have abstract final methods. Final methods cannot be overridden, and abstract 
methods must be implemented 


INTERFACE 


e Interface is the second way to achieve abstraction in java. 
e An interface is not a class, but acts similar 


e To create an interface the keyword interface is used instead of class 


e The main purpose of an interface is providing additional information and 
behaviors to any class that needs it. 


e An Interface also allows creation of abstract methods 
e By default any method created in an interface is < public abstract > ~> =] 
e [Java 8] Only way to create non-abstract methods in an interface is to create a default or static method 


- Static methods: use keyword static before the return type of the method. This will allow a method to be 
created with implementation. 


- Default methods: use keyword default before the return type of a method. This will allow a method to be 
created with implementation. 


INTERFACE 


A 


e By default any variable created will be < static final > and must be initialized 


e To add an interface to a class, keyword implements is used after the class name 


e Inheritance allows only parent class, but it is possible to implement multiple interfaces to a class 


e This is done by adding a comma after each interface after the class declaration. The class must 


implement all the abstract methods from all the interfaces 


e |t's possible to extend interfaces to other interfaces. And unlike regular inheritance interfaces can 
extend as many interfaces as they wish. 


interface 


void ; public static void rotate(); 
} 
interface 


void OPE me public static void increaseSize(); 


class TV is the conrete 
class and it must 
implement the abstract 
methods in the 
interfaces... 


e Constant variables | static final int age = 33; | 
Interfaces renner 


. e Default Methods 
tall have e Static Methods 


Intertaces 
can not — ERSS 


e Constructor 


e Instance variables or methods 


have: 
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ABSTRACTION in my Project 4 


e In my framework | have achieve abstraction by using collections or Map, because it's all interface. 
Most of the cases | come across using List. If we want to access elements frequently by using index, List 
is a way to go. ArrayList provides faster access if we know index. If we want to store elements and want 
them to maintain an order, List is a better choice. 


i) List<String> webs = driver.getWindowHandles(); 
-»create a list first to store web URLs in list 


ii) findElements evaluates multiple elements so therefore will assigned to List «WebElement» 
iii) To handle dynamic elements store it in the list and identify by index: 


List<WebElement> all = driver.findElements(By.tagname("")); 


e In my framework | follow POM and had situations where some pages shared similar actions that were 
similar but worked slightly different, so we usually create an abstract class named BasePage to have all 
common members for every page written in this class such as getPageTitle(). Then each Page class 
(HomePage, LoginPage, DashboardPage etc.) inherit from BasePage. Sometimes one may need to 
change the behavior of methods implemented in superclass. So subclass has freedom to override that 


method where we use polymorphism. This is how we use Abstract class in real projects. 
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POLYMORPHISM e 


e |n java Polymorphism is the ability of an object to take many forms. This is done through the 
reference of an object 


e Three reference types an object can have: 
1. Itself 
2. Super classes 


3. Interfaces which are implemented 


Possible Dog object references: 


reference type 
reference name 
] reference 


] keyword 
] constructor call 
] object 


Static - Dynamic Polymorphism 4 


e [he reference of an object will determine which class members the object can access 


e |f a method is called the object will use the method implementation of the object type. If the method 
is not overridden in the sub class, the super classes method implementation is executed 


e The object will always give the values of the object itself if the reference of the object also has access 
to that class member. If there is a class member that is out of scope of the reference, then there will be 
a compile time error. 


e Polymorphism is achieved by 2 ways: 
1. Static polymorphism is method overloading (Compile time) 
2. Dynamic polymorphism is method overriding (Runtime) 


e One use of polymorphism is for polymorphic collections. Being able to store different types of objects 
that share similar reference types into one data structure. 


Example: WebDriver driver = new ChromeDriver(); 


=>we are initializing Chrome browser using Selenium WebDriver. It also means we are creating a 
reference variable (driver) of the interface (WebDriver) and creating an Object (from ChromeDriver 


ES Continue d 
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REFERENCE CASTING - Polymorphism 4 
e Reference casting is casting the reference to another reference of the object. Casting does 
not happen between objects. 
e Down casting: 

Going from a super class reference to sub class reference. This must be done explicitly. 
e Up casting: 

Going from a sub class reference to a super class reference. This is done implicitly. 


e [he reference type is giving in parentheses next to an object to cast the reference to that 
reference type. 
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COLLECTION & MAP &Arrays 


Arrays 
Collection Framework 
Iterable interface 
LIST Interface 
- ArrayList - LinkedList — Vector classes 


SET Interface 
- HashSet - LinkedHashSet — TreeSet classes 


QUEUE Interface 


- PPriorityQueue, Deque, ArrayDeque - Classes 


MAP Interface 
- Hashmap, LinkedHashMap, Treemap - Classes 


A 
Data structures IN your PROJECT? 


Avoiding ConcurrentModificationException 
Differences: LIST vs SET vs MAP (When...) 
Differences: LIST vs SET 

Differences: ARRAYLIST vs LINKEDLIST 
Differences: ARRAYLIST vs VECTOR 
Differences: ITERATOR vs LISTITERATOR 
Differences: HASHMAP vs TREEMAP 
Differences: HASHSET vs TREESET 
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Arrays e 
e Arrays are a data structure that are used to store multiple values of the given datatype. 


e These values are stored as elements that can be accessed though an index number. The index 
number starts at O for the first element. 


e Key syntax for arrays is the [] symbols 
e The size for arrays is fixed, so it cannot be changed. 


e Declaring an array will give the element default values based on the datatype: O (integers), null 
(objects) 


int[] list1 = new int[4]; 
listi[9] = 
List1[1] 
list1[2] 
Arrays Syntax: List1[3] 
datatype[] arrVar = new datatype[arrVar.length()] 


int[] list2 = {76, 3, 45, 4}; 


1. int[] nums new XDtls2l12e]7j int[] lists = new int[]{25, 4, 1, 99, 8); 


2. Int[] nums TT; e UP. d] E 


int n= List1.length; 


System.out.println("listi = " + Arrays.toString(list1)); 
System.out.println("list2 = " + Arrays. toString(list2)); 
System.out.println("List3 = " + Arrays.toString(list3)); 
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Collections Framework 4 

e The collection framework is built up of interfaces and classes that builds data structures with 
different algorithms to manipulate data. 

e The collection in the framework use different implementations to satisfy the algorithms being applied 
e Only objects can be stored in these data structures 

e At the highest level is the Collection interface, inherits the Iterable interface 

e This interface is implemented in all collection classes 

e Some method that are declared in Collection interface: add, remove, contains, size, toArray 


e The methods declared in the Collection interface are basic operations of the collections that 
implement them. 


Green text indicate 
implementing classes 


Collection 
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Iterable Interface e 


e This interface is inherited by the Collection interface, so any sub class of the Collection interface also 
inherits the Iterable interface 
e Implementing the Iterable interface allows the objects to be used in the for each loop 


e The Iterator interface is an iterator that can be used manually on a collection to enumerate, 
(continually cycle through the elements if there still is one) except the iterator also allows an element 
to be removed. 


Collection Framework Hierarchy in Java 


Iterable 
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Collection All in One Slayt 4 


e All collections are Iterable and all collections are core interface. Sync means slow, not sync means fast 


e LIST: Can store duplicate values, It is ordered. It allows any number of null values. From list we can 
read a certain value by index. The classes that implement List interface: 


- ArrayList(not sync), 


- LinkedList(not sync, can work as stack, queue and dequeue) and 
- Vector(synchronized, slower) 


e SET: can only store unique values (no duplicates), and it is not ordered, it is not used with index. The 
classes that implement Set interface: 


- HashSet(not sync, not ordered, allows null), 
- LinkedHashSet (no sync, ordered, allow null, and maintains double LinkedList) and 
- TreeSet(sorted in ascending order(S-L)) =>(all are class and it implements Set). 
- SortedSet (not sync, ordered, comparable interface and it extends Set) 
e MAP is not collection, it is data structure which is Key and Value format. It cannot have duplicate Key. 


- HashMap is not synchronized, allows one null key and more null value. It is faster 
- HashTable is synchronized, doesn't allow null key, it is slower. 
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Collections 


LIST (ArrayList, LinkedList, Vector, Stack (extends Vector Class)) 

ordered, allows duplicate, has an index, accepts multiple null values 

- ArrayList: Fast random access; Adding and Removing elements slow; Unsynchronized. 

- LinkedList: Slow random access; Adding and Removing elements fast; Unsynchronized. 
Methods: .add(), .remove(), .size(), .get(), .set(), .contains(), .isEmpty(), .indexOf 
(), .addAll(), Collections.sort(), Collections.reverse() 

- Vector: Synchronized. 

- Stack: subclass of Vector(extends Vector); LIFO principle; Last element's index starts 
from 1, not from O0. 

Methods of Stack: .push(), .pop(), .peek(), .search(). 


SET (HashSet, LinkedHashSet, TreeSet) 

no duplicates, no index, maximum one null. 

- HashSet: No order(Random); Accept only one null; No duplicates. 

- TreeSet: Ascending order; Can't have null; No duplicates. 

- LinkedHashSet: Insertion order; Accept only one null; No duplicates. 

Methods: .add(), .clear(), .contains(), .isEmpty(), .remove(), .size(), .toString(), 
.addAll(), .removeAll(), .toArray(), 


MAP (HashMap, TreeMap, Hashtable, LinkedHashMap) 

keys and values connected(entry), no index, no duplicate keys, allows null 

- HashMap: No order; One null key, multiple null values; No duplicate key, multiple 
duplicate values. 
- TreeMap: Ascending order; No null key, multiple null values. 

- HashTable: No order; No null key, no null value; Synchronized, thread-safe. 

- LinkedHashMap: Insertion order; One null key, multiple null values. 

Methods: .put(), .get(), .remove(), .clear(), .containsKey(), .containsValue(), .isEmpty 
(), .replace(), .size(), .toString(), .values(), .keySet() 


List Interface we 


e Inherits the Collection interface 


e This is an ordered collection, which allows full control of elements that are added. These elements 
are accessed by index numbers, starting from O. 


e This collection allows duplicate elements 
e Classes that implement List interface: ArrayList, LinkedList, Vector 


Collection Framework Hierarchy in Java 


Iterable 
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ArrayList - LinkedList — Vector classes e 


e ArrayList: This data structure works similar as an array, but the size is expanded whenever needed 


e LinkedList: This data structure has nodes, which are objects that have data and reference to another 
node. These nodes link for the list collection. Also implements Deque interface. 


e Vector: This data structure is a legacy version of ArrayList. It is a resizable array, but it is synchronized, 
so itis slower. 


e Stack: Class inherits the vector class and acts as a LIFO (last in first out) collection 


Collection Framework Hierarchy in Java 


Iterable 
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SET Interface 


e |nherits the Collection interface 


e This collection is an unordered data structure, meaning the order elements are added is not 
maintained 


e This collection does not allow duplicate elements 
e Classes that implement Set interface: HashSet, LinkedHashSet 


e SortedSet interface inherits the Set interface but allows the ordering of the elements. These 
elements are automatically ordered by their natural order. TreeSet implements this interface. 


Collection Framework Hierarchy in Java 


A 
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HashSet - LinkedHashSet - TreeSet classes 4 


e HashSet: The algorithm used to implement this class is hash table. 

- Short version of hash table algorithm: fast and efficient approach to find elements 
e LinkedHashSet: Implementing the hash table and linked list this data structure will maintain the 
insertion order 
e TreeSet: This data structure is a naturally ordered Set that has additional methods to search for 
information. Does not allow null element 


Collection Framework Hierarchy in Java 


133/ 


QUEUE Interface 4 


e Inherits the Collection interface 

e [his data structure has additional features to insert, extract, and look for information. These method 

have two forms: one which will throw exception upon failure and one which will return a value 
add()==offer(); remove()==poll(); element () ==peek () ; 

e Queues are usually FIFO (first in first out) meaning elements are added at the tail end of the data 


structure. BUT this is not always the case. It depends on the classes implementing this interface, they 
will have to define the insertion direction. 


Collection Framework Hierarchy in Java 


Iterable 
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PriorityQueue, Deque, ArrayDeque - Classes e 

e PriorityQueue: This class implements Queue but does not follow FIFO. This data structure will store 
element with their natural order. null is not a valid element 

e Deque: An interface which allows elements to be used from the beginning or end 


e ArrayDeque: Class that implements Deque which enables it to access elements from both sides of the 
data structure. This collection works faster than ArrayList and Stack 


Collection Framework Hierarchy in Java 


Iterable 
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MAP Interface e 


e The map interface does not implement the collection interface and thus is not a part of the collection 
framework 


e A map is a data structure which works with a key/value format. Each key/value pair is called an entry. 


e Every key is linked to a single value. Maps do not allow duplicate keys but have no issue with 
duplicate values. 


e Classes that implement the map interface: HashMap, HashTable and LinkedHashMap 


e The Map interface is also implemented in the SortedMap interface, which is implemented to the 
class TreeMap 


Collection Framework Hierarchy in Java 
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HashMap, HashTable, LinkedHashMap, Treemap - Classes 4 


e HashMap: The order of entries is not guaranteed over time. It is not synchronized, allows only one 
null key, more null value, but no duplicate key. If there is duplicate key, it returns the first one and 
override others. 


e HashTable: HashTable is synchronized version of HashMap, so it is slower. Doesn't allow null key. 
Doesn't allow duplicate key. 


e LinkedHashMap: This class implements the Map interface and inherits HashMap. The insertion order 
is maintained. 


e TreeMap: Implements the SortedMap interface. The data structure will have an ascending order for 
the keys. Cannot have a null key. 


Collection Framework Hierarchy in Java 
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Differences: LIST vs SET vs MAP (When choose...) 4 


Difference between Set, List, and Map 


ENE Duplicate Obiects | Order | Nulelmens ——— | | Nulelmen | elements 


Set Does not allow. unordered allows only one null element 
collection. 
treeSet(ordered). 


List Allow. ordered Lun d null elements and can hold 
collection. Lun d 


Only keys unique. treeMap(ordered) one null key/ null values 


e |f we need to access elements frequently by using index, List is a way to go ArrayList provides faster 
access with index. 


e |f we want to store elements and want them to maintain an order, List is an ordered collection and 
maintains order. 


e |f we want to create collection of unique elements without duplicates than choose any Set 
implementation. (HashSet...) 


e |f we want store data in form Key and Value than Map is the way to go. We can choose from 
HashMap, Hashtable... 
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Differences: ARRAY vs ARRAYLIST 


A 


Arrays have fixed sizes. Once it is declared, its ArrayLists have dynamic sizes, its size is automatically 


size does not change. adjusted 
Arrays can hold primitives and object ArrayList can hold only objects 
Arrays can have multidimensional --> [][] ArrayList can not have multidimensional 


ArrayList is implementing class of List interface in 


Array is a build in data structure Collect ek E 
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Differences: LIST vs SET 


e List vs Set 


» 


List » Ordered and Indexed Collection, May contain duplicates 


Set » Collection of Unique values, not ordered, no indexing 
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Data Structure IN your PROJECT 4 


e Do you use data structures in your current automation project? 


e Yes, | am very comfortable with data manipulations using Arrays, Collections framework, maps etc. I 
choose my data structure based on my data and requirements: 


- | have used TreeSet to print dropdown list in for non duplicate values and ascending order 


- | have used HashMaps to compare values from a database with expected values 
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Differences: ARRAYLIST vs LINKEDLIST 


e What is the difference ArrayList vs LinkedList? 
- ArrayList is array based, internally uses array 
- LinkedList is a doubly linked list 
- LinkedList consists of nodes/values that are related to each other 
- ArrayList and LinkedList both maintain ordering 
- ArrayList and LinkedList both allow duplicates 


- ArrayList is better to store and get information. LinkedList is better to manipulate 
information 


» 
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Differences: ARRAYLIST vs VECTOR 


» 


e Difference between ArrayList vs Vector? 
- ArrayList is not thread safe/not synchronized 
- Vector is thread safe/synchronized 
- ArrayList is faster than Vector 
- Both allow duplicate values and keep ordering 


- Both are implementations of List interface 
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Differences: ITERATOR vs LISTITERATOR e 


e Difference between Iterator vs Listlterator: 


- Iterator will cycle through the elements from beginning to end, but Listlterator is able to 
go in both directions. 


- |terator can be used in any collection type which implements the collection interface, but 
Listlterator can only be used for the classes that implement List 


- There is a remove method for Iterator, but Listlterator has more operations available like 
- add() 


- set() 
- remove() 
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Differences: HASHMAP vs HASHTABLE 


» 


e Difference between HashMap and HashTable? 

e HashTable is thread-safe/synchronized 
HashMap is not thread safe and faster 

e HashTable does not allow any null key (will throw NullPointer Exception) 
HashMap allows one null key 
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Differences: HASHMAP vs TREEMAP 


» 


e Difference between HashMap and TreeMap? 
e HashMap doesn't maintain any order 
TreeMap will store keys in ascending order 
e HashMap can have one ‘null’ key 
TreeMap cannot have any 'null' key 


e Neither HashMap nor TreeMap are synchronized 
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Differences: HASHSET vs TREESET 


» 


e Difference between HashSet and TreeSet? 
e Both are implementing the Set interface, no duplicate value, no index. 
e HashSet performs better than TreeSet 


e HashSet is not sorted/ordered, but TreeSet provides natural order (ascending sort). 


Set<String> set = new HashSet<>(); store unique value ( not duplicate item) 


sortedSet<String> sSet = new TreeSet<>(); | will remove duplicated data and sort it 
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How you can avoid ConcurrentModificationException 4 


e How can you avoid the ConcurrentModificationException while iterating through collections? 


e You shouldn't change the collection during the iteration, but if you need to, you can use an object 
such as ConcurrentHashMap which is similar to HashMap but will allow you to make modification 


during iteration. 
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EXCEPTIONS N 


- Exceptions DIFFERENCES 
- How to handle Exceptions in Java - Errors VS Exceptions 
- Rules of Exceptions - Compiletime (Checked) VS Runtime (Unchecked) 
- Most Common Exceptions in Java and - throw and throws in Java 
Selenium 


- ElementNotVisible Exception in Selenium 
- Stale Element Reference Exception in 
Selenium 
[. ] checked exception\ 
compile time exception 
[ |] unchecked exception\ 
Runtime exception 
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Exceptions e 


e What is an Exception? 


An exception is an unwanted or unexpected event , which occurs during the execution of a program i.e 
at run time, that disrupts the normal flow of the program's instructions. 


== checked exception\ 

compile time exception 

[ |] unchecked exception\ 
Runtime exception 


= 
== Y 
a Hund 
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Checked (Compiletime) Exception VS Unchecked (Runtime) Exception 4 


* First| want to remind that Java Exceptions are divided in two categories RuntimeException also 
known as unchecked Exception and checked (compile time) Exception. 


e 1-Checked/Compile time Exception must be handled before we can run the program. If ignored 
then program won't compile. 


e 2-Unchecked/Runtime Exceptions where will be thrown during runtime. It compiles without an 
issue if we don't handle it. 


- It is very challenging to predict. Because it won't complain during compile time. 


- Unchecked exceptions are still can be handled using try/catch block. However if we don't use try 


catch block it still compiles. 


Common Unchecked Exceptions Common Checked Exceptions 


- NullPointerException - ClassNotFoundException 
- ArraylndexOutOfBoundException - IOException 


you need to provide a try catch finally block while 
they are descended from java.lang.RuntimeException. performing file operations in Java 


Errors VS Exceptions 


e Both Error and Exception are derived from Throwable in Java. 


» 


e Error represent errors which are generally cannot be handled. 
- For examples: OutOfMemoryError, NoClassDefFoundError 
e But, Exception represents errors which can be catch and dealt. 
- For examples» /OException, NullPointerException, SQL Exception 


e Exception is divided in two categories checked and unchecked Exception. Checked Exception require 
a mandatory try-catch code block to handle it. Unchecked Exception mostly represent programming 
errors (NullPointerException or RuntimeException) 


e Errors are unchecked exception and the developer is not required to do anything with these 
e All the Errors are Exceptions, but the reverse is not true. 


e |n general Errors are which NOBODY can control or guess when it happened, on the other hand 
Exception can be guessed and can be handled 
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How to handle Eceptions in Java (try&catch — throws — throw) 4 


There are 3 options to handle exceptions: Try&Catch block, Throws keyword and Thrown method 


Try&Catch block. This is real exception handling. The finally block follows a try block or a catch block. 
Finally block always executes, no matter what happened. 


- We use try block for the statement that throws an exception. If Exception is thrown then further 
execution is terminated in that try block and catch block will start executing statements. 


Ex: 


- Try/Catch block avoids program termination. | sce 


Yead.sleep(2000); 


- We can have multiple catch blocks. Whatever | systemoutrintsindexor12); 
} 


th e type of Exce pt j O n CO m j n g fro m try b | OC k WI | | be Catch block - is used for declaration of exception type and statements that you want to take when exception happens. 
catch(InterruptedException e)f 
Ca u g ht by th e m atc h j n g catc h b | OC k. mm happened"; 
. . . catch(StringOutOfBoundException e){ 
= When creati ng Catch blocks, generic Exce ption System.out.print("String is problem"); 


} 


type should be declared last. Otherwise specific exception types will not be reachable. 


: . : : : public void shutdown() throws IOException( 
b. Throws keyword which is an Exception declaration in GENERE Unable to shutdown"); 


the method signature. i 


b. Throw method which is used to method body. Throw new Exception(“is Not able to initialized”); 
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throw and throws - Exceptions in Java 4 


e throw and throws are two keywords related to Exception feature of Java programming language. 


e throw keyword is used to throw an exception explicitly, on the other hand, throws keyword means 
passing the exception to next user to handle. 


e |f we see syntax wise than throw is followed by an instance of Exception class throws is followed by 
exception class names. 


e throw new ArithmeticException ("Arithmetic Exception"); throws ArithmeticException; 
e throws is used in method signature to declare Exception possibly thrown by any method, for example 


public void shutdown() throws IOException{ 
throw new IOException("Unable to shutdown"); 


} 


e But throw is actually used to method body. |rnrow new Exception(“is Not able to initialized”); 


e In other words; throws keyword cannot be used anywhere exception method signature while throw 
keyword can be used inside method or static initializer block provided sufficient exception handling. 
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Rules of Eceptions in Java 4 

1. When using multiple catch blocks, Parent Exception type MUST be used in the end. Otherwise child 
exception catch blocks will be 'Unreachable code' and it won't be compiled. 
We use pipe line "|" between exceptions when throwing multiple exceptions. 


If there are multiple catch block, when exception is caught by first catch block, rest of the catch 
block will NOT catch any exception. 


try{ 


}catch(SQLException | InvalidKeyException | BadPaddingException | 
IlllegalBlockSizeException | NoSuchAlgorithmException 
| NoSuchPaddingException e) { 

e.printStackTrace(); 
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Most Common Eceptions in Java and Selenium 


Unchecked: e NoSuchElementeException 
* IndexOutOfBounds exception - it throws when locating an element using by findELement. To 
- while working with arrays/strings handle it | declare IMLICIT WAIT: 


driver.manage().timeouts().implicitlywait(5, TimeUnit. SECONDS); 
NullPointerException 
- if | forget to instantiate the objects e TimeOutException: To handle it declare EXPLICITS WAITS: 


WebDriverWait wait = new WebDriverWait(driver, 5); 
wait.until(ExpectedConditions.titleIs("text")); 


Nu mberFormatException wait.until(ExpectedConditions.titleContains("text")); 
: wait.until(ExpectedConditions.elementToBeClickable(WebElement); 


ClassCastException wait.until(ExpectedConditions.visibilityOf(WebElement)); 


] ' ] wait.until(ExpectedConditions.invisibilityOf(WebElement)); 
ArithmaticException 


NoSuchFrameException, 
Checked: NoSuchAlertException, 
e IOException, NoSuchSessionException, 
* SQLException, Exceptions when we try to interact with an element (click, sendKeys) : 
* FileNotFoundException - StaleElementException 
- ElementNotVisibleException 
- ElementNotinteractibleException 
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ElementNotVisible Exception in Selenium 4 


* This exception will be thrown when you are trying to locate a particular element on webpage 
that is not currently visible even though it is present in the DOM. 


* Also, sometimes, if you are trying to locate an element with the XPath which associates with two 
or more element. 
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» 


StaleElementReferenceException in Selenium 


* There are two reasons for Stale element reference: 
e The element has been deleted entirely. 
* The element is no longer attached to the DOM. 


e We face this stale element reference exception when the element we are interacting is 
destroyed and then recreated again. When this happens the reference of the element in 
the DOM becomes stale. So, we are not able to get the reference to the element. 
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SELENIUM YN 


* Components of Selenium * Hard Assert vs Verify (Soft Assert) e What is Selenium Framework 
* Advantages of Selenium? * driver.get() & driver.navigateto() * Data Driven Framework 

* Limitations of Selenium * Maximize & Resize * Keyword Driven Framework 

* Challenges with Selenium? * Listeners on Selenium e HybridDriven Framework 

* Which tests can be automated * JavaScript Executor 

* Which tests CANNOT be automated * Dropdown in Selenium e isDisplayed(), isEnabled(). And 
* Locators * Screenshot in Selenium is Selected() method 

e XPath vs CSS * Tabs / Windows in Selenium e DOM 


* Locate element using TEXT Windows/OS popups 


* Absolute vs Relative Xpath * Multiple windows in selenium? * How to handle COOKIES? 

e Xpath syntaxes e Alerts - Popups in Selenium e Position/location of the 

e CSS syntaxes * Actions Class WebElement on the page? 
* handle DYNAMIC ELEMENTS * doubleClick & rightClick (contextClick) 

* Handle in DYNAMIC TABLE e scroll down a page using JavaScript 


scroll down if the element is not visible 
Download in Selenium 

Uploading in Selenium 

Headless Browser 

Frames - iFrames 

* FindElement() and FindElements() Find all link present on the web page 

* Exceptions in Selenium Https/SSL certificates Error Handle 

* Selenium Grid * KeyBoard actions - Press Enter, sendK 


e Why | cannot find element? 

e n'th child element using XPath? 
* close() and quit() 

* Implicit - Explicit - Fluent Wait 

e Thread.sleep() 
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Components of Selenium 4 


Selenium is a suite of tools for automated web testing. It is composed of; 


* Selenium IDE(Integrated Development Environment); a Firefox plugin that works for recording and 
playing back. 


* Selenium RC(Remote Control) (1.0) ; is a test tool and is used to work on JS to automate the web 
application. 


e WebDriver (2.0); is a web automation framework and allows you to execute your tests in different 
browsers. 


* Selenium Grid; allows tests to run in parallel across multiple machines. 
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Advantages of Selenium? 


Selenium is a suite of tools for automated web testing. 

Selenium is open source and free to use without any licensing cost 
It supports multiple languages like Java, Ruby, Python, C£... 

It supports multi browser testing 

It has a good amount of resources and helping community 

It supports many operating systems like Windows, Mac, Linux ... 


Interact with the web application 


» 


» 


Limitations of Selenium 


e Selenium supports testing of only web-based applications 

* Mobile applications cannot be tested using Selenium 

e Captcha and Barcode readers cannot be tested using Selenium 

* Reports can only be generated using third-party tools like TestNG or JUnit. 


e As Selenium is a free tool, thus there is no ready vendor support through 
the user can find numerous helping communities. 


* The user is expected to possess prior programming language knowledge. 


| | PN 
Challenges with Selenium? ^ 
e Sync issue 


* Sync issue or | would say timeout issue is one of the most challenging tasks in any test automation 
tool. If we do not handle sync issue then most of the script will fail. In one of the test survey, it as 
found that 8096 of scripts fail due to improper sync while performing actions. 


* We can avoid this by using smart wait which is present in Selenium like implicit wait, explicit 
wait, fluent wait 
e Smart locators —locating elements 


* As we all know that locators are the core part of any scripting and We need to keep on enhancing 
our XPath and CSS for script stability because if XPath and CSS are not proper then it fails in 
upcoming releases. 


* We should always write dynamic or custom XPath or class which can make our script more stable. 
* Pop up handling 


* |n many application, you will find random pop keeps coming and their behavior is not persistence 
so we also have to take care of these unwanted pop up which stops our execution. 


Which tests can be automated 


e functional tests (positive/negative, UI) 
* smoke tests 

* regression tests 

* integration tests 

* API 

e Database 

* end to end testing 


e data driven 


» 


Which tests can not be automated e 


* Performance, load, stress testing, manual ad hoc testing, (These tests are 
done by experts trained in these tools) 


* Pure database testing (if we only test the DB itself), 

* Unit tests..., look and feel based testing (color, shapes, etc.), 
* static testing 

e Captcha is not automated as well. 


Locators 


A 


e A locator is an address that uniquely identifies a web element within a web page. Selenium 
has several different types of locators to identify web elements in web pages. These include: 


* ID 
e Name 
e Class name 


* TagName 
* LinkText 


* Partial Link Text 
e CSS Selector 
e Xpath 


: unique, but can be dynamic 
: unique, but can be dynamic 
: Uses the class name attribute. if it has more than one word, 


separated by space, we can not use it 


: not unique. can be search in a search bar 


: when locate links using their exact text. To locate any element using 


linkText, the tag of that element must be a and it must have a text 


: Uses partial link text to find web elements 
: Works on element tags and attributes 


: Searches elements in the DOM, Reliable but slow 


XPath VS CSS 


with Xpath, we can search elements backward or 


forward... 
works with text 
supports index: (//tag[@attribute='value’])[3] 


XPath has more combination so its powerful 
//tagname[@attribute='value’][@attribute='value’] 


//tag[starts-with(@attribute, ‘some value’)] 
//tagl[ends-with(@attribute, ‘some value’)] 
//tag[contains(@attribute, ‘some value’)] 
//tag[contains(text(), ‘partial text’)] or //tag[.-'exact text'] 
//tagName|[text() = "linked. text'] 

//tagname[ @attribute='value’]/.. (parent) 
//tagname[@attribute='value’]/parent::* (or tagname) 
//tagname| @attribute='value’]/following-sibling::* 
//tagname[ @attribute='value’]/preceding-sibling::* 


//tag/tag/tag 


A 
CSS 


while Css works only in forward direction 


does not support text 

does not support index 

Faster than xpath, easy to read and write, 
tag[attribute = ‘value’] 


tag[id=‘value’] --> tagHidValue or #idValue (# --> id) 
tag[classz'value'] --»tag.classValue or .classValue (. --> class) 


tag[attribute^ = ‘some value’] --> Starts-with 
tag[attributeS = ‘some value’] --> Ends-with 
tag[attribute* = ‘some value’] --> Contains 


tag[attribute = ‘value’ ][attribute = ‘value’] 


tag>tag>tag or tag tag tag 


» 


Locate element using text 


* The only locator that works with text is xpath. 


* Matching exact text : //tag[.=‘text’] 
* Matching partial text : /f/tag[contains(text(), ’text’)] 
back to main 


The Document Object Model (DOM) is a cross-platform and 
language-independent interface that treats an XML or HTML document 
as a tree structure wherein each node is an object representing a part of 
the document. The DOM represents a document with a logical tree. Each 
branch of the tree ends in a node, and each node contains objects. DOM 
methods allow programmatic access to the tree; 


ent Object Model 


= 
- 
A 


Dee um 


Absolute XPath vs Relative XPath e 


* Absolute XPath starts with single slashes (/) and it starts looking for element 
starting from the root element to child element. 


Not stable /html/body/div/div/div/div/a 


* Relative XPath starts with double slashes (//) and it is looking for element 
anywhere in the document. 


It is more stable //body/nav//a 


Xpath syntaxes 


//tag[@attribute=‘value’ ] 
(//tag[@attribute=‘value’]) [5] -> 5th WebElement 


//* |@attribute= ‘value’ |] -> any tag 
//tag[*- walue'] -» any attribute 
//tag[@attribute=‘value’] [@attribute=‘value’] -> and 


To Locate Dynamic WebElement 
//tag[starts-with(@attribute, "value')] 


//taglends-with (@attribute, ‘value’ ) ] 


[ 
//tag[contains (@attribute, "value')] 
//tag[contains(text(), ‘text’)] 
//tag[text() = ^usedId' |] 
//tag[@attribute=‘value’]/. -> parent element 
ee MH RN reer ee -> parent 
Day ates se eel ae eae sibling: (or tag)  -»following-sibling 
//tag[@attribute=‘value’ ]/preceding-sibling: (or tag)  -»preceding-sibling 


//tag/tag/tag 


CSS syntaxes 


tag[attribute-'value'] 


«button id=“disappearing-button”>Don’t click,/button» 
button [id=disappearing-button] 

button#disappearing -> # stands for id -> #disappearing 
a[class=‘nav-link’] -> a.nav-link -> .nav-link 


To Locate Dynamic WebElement 


tagflattribute*=‘some value'] -> starts with 
tag[attribute$-'some value']  -» ends with 
tag[attribute*-'some value']  -» contains 


tag[lattribute=‘value’ ] [attribute=‘value’ ] 


tag»tag»tag 


» 


handle dynamic elements 


* Use explicit waits where necessary 
* Find the static part of the element and write a locator (xpath or css) 


e And then use starts-with, contains, ends-with, text() 


To Locate Dynamic WebElement with XPath 
//tag[starts-with(Gattribute, ‘value’)] -> starts with 


//tag[ends-with(G8attribute, ‘value’) ] -> ends with 
//tag[contains (@attribute, "value')] -> contains 
//tag[contains(text(), "text')] -» contains 
//tag[text() = ^"usedId'] -» text 


To Locate Dynamic WebElement with CSS 
tag[attribute^-'some value'] -> starts with 


tag[attribute$-'some value']  -» ends with 
tag[attribute*-'some value']  -» contains 


» 


Handle in dynamic table e 


* Use custom XPaths and CSS locators 


- Xpath: contains, starts with, ends with, contains text. 


- By finding the element in relation to another stable element using parent, child, 
preceding-sibling, following-sibling relationships 


* | have utility methods that work with table. | have method that returns all the column 
names. | have a method that takes a table, number and returns all the data in that row. 
How to handle Web Tables/grid? 


Table tag used fortable data is arranged in a grid format 
o thtagforcolumn name Example — 


<tr> 
<th>FirstName</th> column names on the very top row 
<th>Lastname</th> 
«th»Age«/th» 

«/tr» 


o </tr> trtag used to indjcate a row, applies to whole column td tag to indicate a column in a row Example 


<tr> 
<td>Danny</td> actual_data_on_the_very_first_row 
<td>Smith</td> 
<td>29</td> 

</tr> 


Some tables have tbody Used to indicate the data of the table, usually does not include column names ( th ) 


Why | cannot find element? 


* Locator changed 

* There is an iframe 

* Waiting time issue, page is loading slowly 

* Element is dynamic, locator cannot find it. Use dynamic locator. 
* Page is not fully loaded/opened. This is also waiting time issue 
* Page changes and that element does not exist anymore 


» 


n'th child element using XPath? 


There are two ways: 
1. using square brackets with index position 
div [2] will find the second div element 


2. using position ( ) method 
div[position()=2] willfind the second div element 


» 


» 


close() and auit 


* driver.close() —» is used to close the current browser. 
It only closes the current tab 


* driver.quit() —» is used to close everything, all browser instances. 
It closes all browsers, tabs, windows, every thing that was 
opened with selenium 


Implicit Wait vs Explicit Wait vs Fluent Wait a 


* Implicit wait —> we use this wait to find elements in a specific time period that we defined. It 
works with findELement method. If locater cannot find the element in a determined time it throws 
“NoSuchElement” exception. If find earlier it jump to the next step. We set it only one time using: 

driver.manageO.timeoutsO.implicitlywait(5, days) 

* Explicit wait —» we use this wait for certain actions or conditions to happen. We call this every 
time when we want to wait. If locater can not find the element it throws "timeout" exception. If 
find earlier it doesn't wait the whole time period and jump to the next step. 

WebDriverWait wait = new WebDriverWait(driver, 5); 


wait.until(ExpectedConditions.visibilitvOf(element)); 
elementToBeClicable(WebElement) - — titlels("text") -- . titleContains("text"); 


* Fluent wait —> is used If the element is sometime visible and sometime invisible for a nonperiodic 
time frame. 
Wait wait = new FluentWait(driver). 


withTimeout(Duration.ofSeconds(30)). 
pollingEvery(Duration.ofSeconds(2)).ignoring(Exception.class); 


Thread.sleep() 


* Threat.sleep() slows down selenium to catch up the webelement 
e It throws exception, so we must handle the exception. 


» 


» 


FindElement() and FindElements() 


* FindElement returns first WebElement. 


If the element not found, gives "NoSuchElement" exception. 


* FindElements returns List of WebElemet ( List <WebElement> ) 


If the element is not found it returns NULL value (it does not throw Exception) 


Exceptions in Selenium A 
e The most common exceptions in Selenium are: 


- TimeoutException is thrown when a command performing an operation does not complete 
in the stipulated time. To handle it | use EXPLICITS WAITS. 


- NoSuchElementException is thrown when an element with given attributes is not found on 
the web page. Check if locator is correct, Check if timing is correct, Check if element is hidden 
inside an iframe. To handle it | declare IMLICIT WAIT 


- ElementNotVisibleException: This exception is thrown when the element is present in DOM 
(Document Object Model), but not visible on the web page 


- StaleElementException: This is thrown when the element is either deleted or no longer 
attached to the DOM. To handle it, | use try&cath block or refresh the page and use explicit wait. 


e NoSuchFrameException 
e NoSuchAlertException 
e NoSuchSessionException 


Selenium Grid A 


e We use Selenium Grid for Parallel Execution. It consist of one Hub VM + multiple Node VMs. Tests 
are actually executed on the Nodes, not on the Hub. Nodes can be Windows, Linux, Mac, also can 
have different browsers like: Chrome, Firefox, Edge, Safari etc. 


e We use Docker Container via the EC2 machine on AWS to create Virtual Machines to run parallel 
execution. don't mention Docker Container on the interview 


e | have only one HUB as a main centralized machine in order to run test cases. | create more than one 
NODES to execute test cases in different browsers. Each Node represents a different browser. 


* Instead of WebDriver driver = new Chromedriver(); ==> | write; 
WebDriver driver = new RemoteWebDriver(URL, capabilities) 
eTo start a HUB to run I write on the terminal that; 
Java —jar selenium-standalone-<version of jar file (3.11.0.jar)>-role hub 


If | want to add different port | write; -port 4441 

We configure our BrowserFactory Class with options called RemoteDriver 

o We pass IP address of the Selenium Grid Hub as desired capability 

o ChromeOptions chrOptions = new ChromeOptions() ; 

o driver = new RemoteWebDriver( new URL("http://34.235.0.4:4444/wd/hub" ), chrOptions) ;} 


A 


Hard Assert vs Verify (Soft Assert) 


In HardAssert; In SoftAssert; 

when test fails; the test execution when verify test fails, the test does NOT 
STOPS, and all test steps after that line of stop, but it reports the failure regardless 
code are skipped. is true or false. 


If there is, Selenium jumps the next Test It DOSEN'T STOP, but it reports the 


method. failure. 
Assert class provides assertion methods Soft assertions do not stop execution if test fails. 
Assert.assertEquals(valuel, value2) SoftAssert softAssert - new SoftAssert(); 
Assert.assertNotEquals(valuel, value2) SoftAssert.assertEquals(valuel, value2); 
Assert.assertTrue(boolean condition) softAssert.assertNotEquals(valuel, value2); 


As se FE. assertFalse( boolean condition) softAssert.assertTrue(valuel, value2 = 


driver.get() and driver.navigateto| | e 


* driver.get("url") is used to open an URL and it will wait till the whole page 


gets loaded 


* driver.navigateto("url") is used to navigate to an URL and it will NOT wait till 
the whole page get loaded 


GUID 
String mainGUID = driver.getWindowHandle(); 
See allGUIDs - driver.getWindowHandles(); 
driver.switchTo().window(guid); 


driver.close(); 
o driver.switchTo().window(mainGUID); 
for(String guid : allGUIDs){ 


driver.switchTo().window(guid); 
if(driver.getTitle().toLowerCase ().contains("cnn")){ 
driver.findElement (By.id("dsk")).sendKeys("Michael"); 
break; 


} 


Maximize & Resize 


e To maximize the size of browser window: 


driver.manage().window().maximize(); 


* To resize browser Window : 
- Create object of Dimensions class 
Dimension newD = new Dimension(480,620); 
- Resize the current window to the give n dimension 


driver.manage().window().setSize(newD); 


e If maximize() will NOT work, so | have a code for that : 


ChromeOptions options = new ChromeOptions(); 
options.addArguments("startmaximized"); 


» 


Listeners on Selenium e 


* Listener is defined as interface that modifies the default TestNG's behavior. As the name suggests 
Listeners "listen" to the event defined in the selenium script and behave accordingly. Listeners allows 
customizing TestNG reports or logs. 


* The types of Listeners in TestNG are, 
* |AnnotationTransformer 
* |AnnotationTransformer2 
e |Configurable 
* |ConfigurationListener 
e |ExecutionListener 
* |Hookable 
e IInvokedMethodListener 
e IInvokedMethodListener2 
e |MethodlInterceptor 
e [Reporter 
e |Suitelistener 
* |TestListener 


JavaScript Executor e 


JavaScriptExecuter is an interface that provides us to execute JavaScript code 
thorough Selenium driver. 


It provides "executeScript and executeAsyncScript" methods to run JavaScript in the 
context of the currently selected frame or window. 


JavascriptExecuter js = (JavascriptExecuter) driver; 


js.executeScript(Script, Arguments); 


Dropdown in Selenium e 


also see this 


Select class is used to deal with drop down list in selenium. To create a select object we need to 
pass a webElement as constructor. That element must have the select tag 


- select by Index: Takes a int param, selects based on the index O based. 
- select by visible text: takes a string, select based on the text displayed. 
- select by value: takes a string parameter selects based on the value attribute of the option 


Example: 
WebElement element = driver.findelement (by.id("dropdown")); 
Select list = new Select (element) 

list.getFirstSelectedOption; -> select first the option 
list.getOptions() —> returns all the options 
list.selectByVisibleText("text") —> select by text 
list.selectByIndex(index) —> select by index 
list.selectByValue (value) —> select by value 


List<Webelement> options = list.getOptions(); //all options are in the list 


Screenshot in Selenium 
e | can take a screenshot by using the TakeScreenshot function. 
e | can save that screenshot by using getScreenshotAs()method. 


e Example: 


File scrFile = ((TakeScreenshot)driver). 
getScreenshotAs (output Type.FILE); 


» 


Tabs / Windows in Selenium A 


Selenium WebDriver handles one tab or window at a time. In order to control another tab we always need 
to switch to that tab. 


First of all, we need to determine the current windeow using the driver.getWindowHandle() method. This 


method returns a unique handle value. 


To be able to switch we need to get the all window handles using driver.getWindowHandeles() method. | 


put all the handles to the Set Interface. And then in the for loop | compare the current window handle 
with each handle in the Set list. When | find the current window handle, | switch to that window. 


Handling Pop-up windows 


String currentWindow = driver.getWindowHandle() —> returns a unique handle, save main window 
Set «String» windows = driver.getWindowHandles(); -> returns all the tabs 
for (String handle : windows) { 
if (handle.equals(currentWindow)) { GUID 


driver.switchTo().window(handle); } } 


A 


Windows/OS popups? 


e Selenium doesn’t support windows-based apps, it is an automation testing 
tool that supports only web application testing. We could handle windows- 
based popups in Selenium using some third-party tools such as AutolT, 


Robot class 
* driver.getWindowHandle() —>This will handle the current window that 
uniquely identifies it within this driver instance. 


* driver.getWindowHandles() —» To handle all opened windows 


Handling Pop-up windows 
String currentWindow = driver.getWindowHandle() —» save main window 
Set «String» windows = driver.getWindowHandles(); 
for (String handle : windows) i1 
if (handle.equals(currentWindow)) 1 
driver.switchTo().window(handle); } } 


Multiple windows in selenium? e 


* Selenium stays on one window. If you open a window and then 5 tabs popped open, selenium is focused on 
the first window 
* |f you are on a new window and you tell selenium to print an element on the default window, it will still 
work even that user's focus is on the new window. Must switch to new window: 
- Use windowHandle() 
- Driver.getWindowHandle() 
- Everytime Selenium opens a browser, it's going to give an index ID for the page called Handles 
- Returns the handle/id of current page (as a string) 
- driver.switchTo().window(string handle) 
- driver.getWindowHandles() for multiple windows 
Returns a Set of window handles 
- Switch using titles: 
for(string handle: driver.getWindowHandlesO)1 
driver.switch ToO.Windowc(handle) 
if(driver.getTitleQ.equals(targetTitle) 
break; 


Alerts - Popups in Selenium 


If 
We cannot locate alerts using inspect tools (id, name, css, xpath etc..) 
Alerts are not html windows 


Handling Alerts using Alert Interface 


Alert alert = driver.switchTo().alert(); 
alert.dismiss() —> click "Cancel" on popup 
alert.accept() —» click "Ok" on popup 
alert.getText() — to get text from popup 
alert.sendKeys("text") — to send text 


e When using Selenium, if alert shows up as part of the automation, we have to handle that alert before 
proceeding. 

e Otherwise we get: UnhandledAlertException, and test exits. 

e We can use Explicit wait / WebdriverWait to check whether the alert is there or not. 

o wait.until(ExpectedConditions. alertlsPresent ()); 


Actions Class 


Actions Class 
Actions actions = new Actions(driver); 


actions 
Actions class is used for .moveToElement(elementOne) —» hover over an element 
advanced mouse and keyboard .pause(1000) —> Thread.sleep() between actions 
interactions such as; .moveToElement(elementTwo) —» move to second element 


.build() — use when chaining actions 


e a a 1 
Hover over element .perform() —> comes last in chain of actions 


* move to element actions 
.dragAndDrop(sourceElement, targetElement) —> drag & drop 
* Scroll up/down .perform() —» comes last in chain of actions 
* Double click actions | 
. cLickAndHold(sourceElement) 
* Right click .pause(1000) —» Thread.sleep() between actions 


.moveToElement(targetElement) —> move to second element 
.release() — drop element 
* keyboard combinations .build() —» use when chaining actions 
.perform() —> comes last in chain of actions 
actions 
. sendKeys (Keys.ARROW_UP) 
. sendKeys (Keys. ARROW DOWN) 
.SendKeys(Keys.PAGE DOWN) —> to scroll down 
.sSendKeys(Keys.PAGE UP) — to scroll up 


* drag and drop 


Double click and Right click in Action class e 


* To perform any actions against web element using actions class, we need to locate the 
element first: 


WebElement el = driver.findElement 


* Double Click (doubleClick): 


Actions actions = new Actions (driver).perform 
actions.doubleClick(eD.performO 


actions.moveTo(el).perform actions.doubleClick.perform 
actions.moveTo(el).doubleClickO.build.performO 


* Right Click (contextClick): 
actions.contextClick(elementLocator).performO; 


scroll down a page using JavaScript in Selenium? ek 


* We can scroll down a page by using window.scrollBy() function. Example: 


((JavascriptExecutor) 
driver).executeScript("window.scrollBy(0,500)"); 


e Or | use Action class: 


Actions actions = new Actions(driver); 


actions.sendKeys (Keys.ARROW UP) 
.SendKeys (Keys.ARROW DOWN) 
.sendKeys (Keys.PAGE DOWN) —> to scroll down 
.sendKeys (Keys.PAGE UP) —> to scroll up 


scroll down if the A 


WebDriver driver = new ChromeDriver(); 
JavascriptExecutor jse -(JavascriptExecutor)driver 
.Jse.executeScript('window.scrollBy(0,250)', ''); 


* OR, we can do as follows: 


jJse.executeScript('scroll(0, 250);'); 


Download in Selenium e 


* Selenium itself cannot verify file downloads, can click on download link but 
can't go outside the browser and open the downloaded file 


e Other tools need to be used for that Robot and AutolT 


Find dropdown list using getOptions 


e We can find if a particular option is present in the dropdown list, using getOptions. 
o Select dropdown = new Select(dropdownElement); 

List<WebElement> allElements = dropdown. getOptions(); 

boolean presenceOfElement - false; 

for (WebElement element : allElements) { 


String dropdownOption Value = element. getText(); 
if (dropdownOptionValue. equals("Baku")) { 
presenceOfElement - true; 

} 


} 

e Alternatively, we can use xpath to find it as well: 
o driver.findElement (By.xpath("//select 
[Qid-'editor'|//option[text()2'Baku']" )); 


Uploading in Selenium e 


In order to upload file using selenium we need to locate the upload button in the DOM 
html. Then we do sendKeys by passing the path to the file. 


* To upload file in selenium; 

* First, | locate the element which takes the path of the file (Choose file button) : 
WebElement input = driver.findElement ("id"); 

* And then | provide the path to the file using the sendKeys method : 
input.sendKeys("/path/to/file" + Keys.ENTER); 


IN 
Headless Browser A 
* Headless browser is a browser that does not open, it runs as a background service / 


program. 


e | can do headless testing. One option is that in the runner class there is Dry keyword 
within the Cucumber Options. | make it "true" iot run headless browser testing. 


* The another way; | have a driver class that can open different browsers including headless 
browsers: 


case "chromeHeadless'': 
WebDriverManager.chromedriver().setup(); 


driver = new ChromeDriver(new ChromeOptions().setHeadless(true)); 


break; 
case "firefoxHeadless": 


WebDriverManager.firefoxdriver().setup(); 


driver — new FirefoxDriver(new FirefoxOptions().setHeadless(true)); 


break; 


| a 
Frames - iFrames 
* |f we want to interact with elements inside frames/iframes, we have to switch to that 


frame first. Otherwise we get no such element exception. We cannot jump directly one 
iframe to another iframe. First we have to reach to parent or defaultContent frame. 


* We can switch frames using 3 options. 
driver.switch ToO.frame("*id or name") —> using the name or id of the element 
.frame(index) —» using the index of the frame stars with O 


frame(webelement) —> WebElemet 


Handling iFrames 

driver.switchTo().frame(“id goes here") —> switches to frame 
driver.switchTo().parentFrame() —» switches back to parent frame 
driver.switchTo().defaultContent() —» switches back to original page 


Find all link present on the web page A 


e TagName should be “a”. 


* | locate the webelements starts with tagname “a”. 


* | also use driver.findElements instead of driver.findElement since the list of webelements 
will return. 


List«WebElement» list = driver.findElements (By.tagName ("a")); 


Https / SSL certificates Error Handling A 


SSL (Secure Sockets Layer) is a standard security protocol for establishing secure connection between 
the server and the client 

Browser and the server use SSL Certificate mechanism to be able to establish a secure connection. 
SSL works through a combination of programs and encryption/decryption routine that exist on the 
web server computer and web server browser. 

When secure connection is not established between the server and client due to certificate SSL 
certificate error will occur 


Need to adjust our script in such a way that it will take care of SSL Exception/error by itself through 
Selenium Web driver. 


e We need to create instance of DesiredCapabilities class : 


‘ DesiredCapabilities handlSSLErr = DesiredCapabilities.chrome () 
CHROME, IE > UI handlSSLErr.setCapability CCapabilityType.ACCEPT_SSL_CERTS, true) 
WebDriver driver = new ChromeDriver (handlSSLErr); 


e JE > UI DesiredCapabilities capabilities = new DesiredCapabilities(); 
capabilities.setCapability(CapabilityType.ACCEPT. SSL. CERTS, true); 
System.setProperty("webdriver.ie.driver","IEDriverServer.exe"); 
WebDriver driver = new InternetExplorerDriver(capabilities); 


* API Response response - given().relaxedHTTPSvalidation(). when(). get(baseURL); 


sendKeys(“text” + Keys.ENTER|) 


* To press Enter key using Selenium WebDriver, 
* We need to use Selenium Enum keys with its constant Enter 


WebElement button = driver.findElement(By.xpath("xpath")); 
button.sendKeys(“some text" + Keys.ENTER; 


* How to input text in the text box without calling the sendKeys()? 


/ /Use javascriptExecutor 
JavascriptExecutor JS = (JavascriptExecutor)webdriver; 
//To enter username 


JS.executeScript(''document .getElementById( ‘User’ ).value= 'www.google.com'"); 
//To enter password 
JS.executeScript(''document.getElementById(*pass?).value-" tester’”); 


If you want to click multiple keys : 


Actions act = new Actions(driver); 


» 


What is Selenium Framework N 


e Framework is the blueprint of test automation. It includes your folder structures, where to save you function 
library, test results, test data, resources. There are mainly 3 type of frameworks created by Selenium WebDriver 
to automate test cases: 


Data Driven Framework 
e All of our test data is generated from some external files; 
- excel or 
- scenario outline in feature file or 
- TestNG Data Provider 
e Selenium WebDriver is a great tool to automate web-based applications. But it does not support read and 
write operations on excel files. Therefore, we use third party APIs like Apache POI. 


Keyword Driven Framework 

e Keyword driven testing is a scripting technique that uses data files to contain the keywords related to the 
application being tested. 

e Keywords are written in some external files like excel file. Java code will call this file and execute test cases. 


HybridDriven Framework 
e A combination of the DDF and KDF is commonly said to be HDF. 
e Both the test data and test action are kept in external files. 


isDisplayed() - isEnabled() - is Selected() method N 


e isDispalyed() -> verifies the presence of a web element within the web page. 
If found -> true, If not found -> false 
checks for the presence of all kinds of web elements available 

e isEnabled() -> verify if the web element is enabled or disabled within the web page. 
is primarily used with buttons 

e isSelected() -> verifies if the web element is selected or not 


is used with radio buttons, dropdowns and checkboxes. 


e To check Element Present: a net ei © Tochecktext present 
if(driver.findElements(By.xpath("value")).size() != @){ if(driver.findElement(By.cssSelector("a > font")).isDisplayed()){ 


: i : " : . riii ee if(driver.getPageSource().contains("Text to check"))( 
i ide du Element is Present"); ER MEN Element is Visible"); System.out.println("Text is present"); 
else 
; " , "T else 
System.out.println("Element is Absent");) System.out.println("Element is InVisible"); ) ) { 


System.out.println("Text is absent"); ) 
* or 
e To check Enable: 
i i i " " Im 
1f(driver.. findElement (by. xpath( value )) null){ if(driver.findElement(By.cssSelector("a > font")).isEnabled()){ 
System.out.println("Element is Present"); Systen.out.println("Element is Enable"); 
jelse{ jelse( 
System.out.println("Element is Disabled"); ) 


boolean selectedOrNot = optionElement. isSelected(); 


System.out.println("Element is Absent"); ) 


How to handle COOKIES? 4 


driver.manage().getCookies(); // Return The List of all Cookies 
driver.manage().getCookieNamed(argO);  //Return specific cookie according to name 
driver.manage().addCookie(argO); //Create and add the cookie 
driver.manage().deleteCookie(argO); // Delete specific cookie 


driver.manage().deleteCookieNamed(argO); // Delete specific cookie according Name 


driver.manage().deleteAllCookies(); // Delete all cookies 


verify the position of the WebElement onthe page? @® 


e WebElement class has a get Location method with returns the top left corner of the 
element 


element.getl ocation ( ) ; 


Page Factory class 


e Page Factory class comes with Selenium. 
e And itis used whenever we create page object classes. 
e |ts purpose is to initialize webElements that were defined in the class. 


Log4j 


e | use Log4J for logging. | always log important steps in the test execution. That helps me to debug when there is a failure 
e Log4J is not a replacement for HTML reports. 
Log4J has 3 components: 1) Loggers - responsible for logging information - we use only this as testers 
2) Appenders - used to deliver LogEvents to their destination 
3) Layouts - responsible for formatting logging information in different styles 
To setup Log4J : add Apache Log4J dependency in pom.xml 
create a new lod4j.properties file and save in the Project root folder 


create an object - static final Logger logger = LogManager.getLogger(SelectHelper.class); 
use that object to call logger methods: logger.info(); logger.warn(); logger.debug() 


TESTNG - JUNIT 


» 


e What is TestNG? XML language, XML vs HTML 
* What is assertions in TestNG? 
* Difference between JUnit and TestNG 


e Annotations in TestNG-1 (Q Test, (9 Method...) 

* Annotations in TestNG-2 (others) 

* |gnore the Test 

* How to EXCLUDE a particular test method from test execution? 
* Cross Browser and Parallel Test in TestNG 

* Group test using TestNG? 

* Group of Groups in TestNG? 

* Reports in TestNG 

e (OQ Factory and @DataProvider annotations? 

* Rerun failed test cases in TestNG and JUnit 


* How to run Cucumber with Testng? 
* Excel in Framework 


* Regular expression (REGEX) in testing.xml file to search @Test methods containing "smoke" keyword? 
e @Test(threadPoolSize=somelnteger) 
* What does the Test TIMEOUT mean in testing? 
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Mm 
What is TestNG ds 


* TestNG is a centralized controller testing framework and allows us to 
manage run different test cases, then create reports, logs etc. 


e Batch execution is also possible with TestNG. Let's say we have 100 test 
cases and TestNG can run them one by one. 


* TestNG is also provide us Optional Execution opportunity. So we can skip 
some test cases (making them enable or disable; (9 Test(enabled-false)) 


| | | N 
What is assertions in TestNG? 


e HARD ASSERT: Critical; stop/failure Assert 


It takes one boolean argument and String message. It Asserts that if 
the condition is true. If it isn't, test fails and stop running the code, it 
throws an AssertionError. If it there is another test method it jumps to 
this test method. 


* SOFT ASSERT: Non critical; failure/continue SoftAssert 


Soft Assert does not stop and does not throw an exception when an 
assert fails and It reports the fails and continue to run. 


Difference between JUnit and TestNG e 


TestNG Annotations: (O Test,  BeforeMethod, 
(0 AfterMethod, @BeforeClass, @AfterClass, @BeforeSuite, 
@AfterSuite, @BeforeGroups, @AfterGroups 


JUnit Annotations: @Test, @Before, @After, 
@BeforeClass, @AfterClass, (Ignore 


TestNG provide htm! report JUnit not 


TestNG has @Dataprovider annotation which is same as 


. r A . ni 
Cucumber Scenario Outline for Data Driven Testing. JUnit not 


but JUnit doesn't support to parallel test, so we use 


In TestNG, we can do parallel testing PS AREA 


TestNG support group test but JUnit doesn't support 


TestNG and JUnit both of them have parameterize testing but TestNG parameterized test configuration is very easy to 
configure. There are two ways to achieve parameterization in TestNG; 


- @Parameters and TestNG xml file 


- @DataProvider 


Annotations in TestNG-1 e 


e @ Test - actual test. Run in alphabetical order. By default priorityzO. If we add priority, 
they will run in that order (lowest->highest). 
Hierarchy => BeforeSuite > BeforeTest > BeforeGroups > BeforeClass > BeforeMethod>Test 

e @AfterMethod - methods with this annotation always run after the test method. Will 
execute after each method. Doesn't matter if test passes or fails (close browser, log out, 
delete test data, report close connections] 

e @BeforeMethod - executes before each method {prepare test data, set path, open 

browser, create connections, initialize classes, open url, login] 

(0 BeforeClass - executes once in the beginning {prepare test data, set path, open 

browser, create connections, initialize classes, open url} 


@AfterClass - executes once in the end {close browser, log out, delete test data, report 


close connections} 


e @lgnore - ignores Test Case 


» 


Annotations in TestNG-2 


e (enable = true/false) —> true: executes the test case, false: ignore the test case 
* (timeout = int milliseconds) —> gives time limit to the test case 

* (priority = int level) —> deciding order of execution 

* (description = "text") —> is used for the test description 

* (expectedexception = Exception) —> is used for unchecked exceptions 


* DependsOnMethods = “test method name" You can add multiple test names. If the first 
one fails, the 2nd test won't run at all 


* (invocationCount = int count) —> decides how many times the test cases should be 
executed : 
@Test (invocationCount=10) //runs 10 times 


Public void testcase() { 
// to do 


} 


Ignore the Test in TestNG 


To ignore the test case, we use the (enabled - false) parameter : 


aTest(enabled-false) 


Example: 
aTest(enabled-false) 
public static void TestX()í 
// to do 


» 


How to EXCLUDE a particular test method from test execution? @& 


* By adding the exclude tag in the testing.xml 


«classes» 
«class names"TestCaseName"» 
«methods» 
«exclude nameb"TestMethodNameToExclude"/» 


«/methods» 
«/class» 
«/classes» 


Cross Browser and Parallel Test in TestNG 


A 


e |n my previous project | used testng.xml file for cross browser testing. 


* Basically, inside the suite there are 3 keys (name, thread count, parallel) and | created 2 
different tests, one of them is for Chrome and the other one is for Firefox. 


* There is also parameter annotation and include name and value; name is browser and 


value is Chrome. 


- |n xml file write; 

parallel="tests” thread-count="4” 
- Thread-count is how many browser do 
you want to open at the same time 
- In xml file you can add .* to run 
everything 
- Ex: «package name=”.*”></package> 


<?xml version="1.0" encoding="UTF 8"?» 
<!DOCTYPE suite SYSTEM ...> 


<suite ...> 
«test name-"ChromeTest" ... > 
«parameter name-"browser" value="chrome"/> 
«classes» 
«class name="testsuite..."/> 
</classes>| 
</test> <! First Test > 
«test name="FireFox" ... > 
«parameter name="browser" value="FireFox"/> 
<classes> 
«class name="testsuite...."/> 
</classes> 
</test> <! Second Test > 


</suite> <! Suite > 


Group test using TestNG? 


@Test (groups={"smokeTest”, "functionalTest"]) 
public void loginTest () { 


System.out.printin("Logged in successfully”); 


back to main 


XML language, XML vs HTML 

XML stands for eXtensible Markup Language. It's a markup language like HTML. 

It was designed to store and transport data (like JSON). XML does not do anything, its just information wrapped in tags 
HTML - is about displaying content (information) 

XML - is about storing and transporting content (information) 


XML tags are defined by author (not predefined like HTML tags are) 


! e 
Group of Groups in TestNG? 


e These groups are called metagroups. 
e Example: 


You might want to define a group all that includes smokeTest and FunctionalTest. 
Let's modify our testng.xml file: 


«groups» 
«define name="all”> 
«include name =”"smoke Test" /» 
«include name = “functionalTest”/> 
</define> 
<run> 
«include name = “all” /> 
</run> 
</groups> 


» 


Reports in TestNG? 


* TestNG offers two ways to produce a report 

. Listeners are notified in real time of when a test starts, passes, fails, etc... 

s Reporters are notified when all the suites have been run by TestNG. 

* The IReporter instance receives a list of objects that describe the entire test run. 

* |n TestNG, Extent is also an HTML reporting tool which gives detailed test steps and 
screenshots. It also provides metrics on the test results. 


ExtentReports class is used to start and build the reports. Only 1 instance is needed. 
ExtentHtmlReporter class creates HTML report file. 
ExtentTest defines a test, enables adding logs, authors to the test etc. 
XML runner is used to run multiple tests from different classes 
1. Right click on project name 


24. New File => Lestng runner.xml 


e . AAN 
@Factory and @DataProvider annotations? A 


* @Factory executes all the test methods present inside a test class using a separate 
instance of the class with different set of data. 

* @Factory is declared in a different class from the @BeforeClass and @TestMethod. So 
@BeforeClass runs everytime whenever a data object called from the class where 
@Factory in it. 


e @DataProvider is a test method that uses DataProvider will be executed the specific 
methods multiple number of times based on the data provided by the DataProvider. 
. SO 
@BeforeClass runs only one time. 


* By using @DataProvider annotation, we can create a Data Driven Framework. 


ENIM) 


(O Factory and @DataProvider annotations? e 


public class SimpleTest 


1 
private String param = ""; 
public SimpleTest(String param) { 
this.param = param; 
} 
@BeforeClass 
public void beforeClass() 1 
System.out.println("Before SimpleTest class executed."); 
} 
@Test 
public void testMethod() { 
System.out.println("testMethod parameter value is: " + param); 
i 
} 
public class SimpleTestFactory 
{ 
@Factory 
public Object[] factoryMethod() { 
return new Object[] { 
new SimpleTest("one"), 
new SimpleTest ("two") 
}; 
} 
} 


Let's run the above test. 


Before SimpleTest class executed. 
testMethod parameter value is: two 
Before SimpleTest class executed. 
testMethod parameter value is: one 
PASSED: testMethod 

PASSED: testMethod 


As you can see from the previous test results, the beforeClass() method is executed before each 
execution of testMethod(). This shows that factory implementation executes the test method for 
each individual instance of the test class. 


public class DataProviderClass 


1 
@BeforeClass 
public void beforeClass() { 
System.out.println("Before class executed"); 
} 
@Test(dataProvider = "dataMethod") 
public void testMethod(String param) { 
System.out.println("The parameter value is: " + param); 
} 
@DataProvider 
public Object[][] dataMethod() 1 
return new Object[][] { { "one" }, { "two" } }; 
} 
} 


Let's run the above test. 


Before class executed 

The parameter value is: one 
The parameter value is: two 
PASSED: testMethod("one") 
PASSED: testMethod("two") 


As you can see from the preceding test results the class beforeClass() is executed only one 
time irrespective of how many times the test method is executed. 


| | | e 
Rerun failed test cases in TestNG and JUnit 


By using TestNG 


1. After the first run of an automated test run. Right click on Project - click on 
Refresh 


2. A folder will be generated named "test-output" folder. Inside "test-output" 
folder, you could find "testng-failed.xml" 


|" 


3. Run "testng-failed.xml" to execute the failed test cases again. 


e |f you have three test cases and all the test cases are executed successfully, 
that means you are not able to see this folder under the test-output folder. 
This folder will appear only when if there is a test case that failed. Then run 


this file, it will run only failed test cases. 


| | | e 
Rerun failed test cases in TestNG and JUnit 


By using JUnit 

e First, | add this line to the cukesrunner, in the plugins option: "rerun:target/rerun.txt" 
rerun creates a text file with list of failed scenarios 
target/rerun.txt --> location and file name 


* Second, | create a new runner class 
1. Right click on runners package 
2. New --> java class 
3. Name: FailedTestRunners.java 
4. OK 


e Then | add the features options to the new runner file as like: 
features="@target/rerun.txt" This means, run all the scenarios listed in the rerun.txt file 
e | also change the report file path to avoid overriding the success reports. 


e Then | add the Cukes runner and the failed test runner to the pom file inside «include» tag. 


! e 
How to run Cucumber with TestNG? 


* Add cucumber-testng maven dependency to pom.xml file (version 
6.14.3) 


«!—— https://mvnrepository.com/artifact/org.testng/testng --» 
«dependency» 
<groupId>org.testng</groupId> 
<artifactId>testng</artifactId> 
<version>6. 14. 3</vers|ion> 
<scope>test</scope> 
</dependency> 


e Make CukesRunner extend to AbstractTestNGCucumberTests 
1.cucumber-testing - > pom.xml 


2.CukesRunner extends AbstractTestNGCucumbertTests{ } 


Excel in Framework 


Apache POI Used to read data from external sources such as excel, csv, text files. 


e 1st dependency is used to connect to Microsoft files. 
e 2nd -to connect to new office. 


//takes the file path and creates connection to the file 
private FileInputStream fileInputStream; 

//represents excel file 

private Workbook workbook; 

// represents a single sheet 

private Sheet workSheet; 


Create @BeforeTest 


@Beforelest 

public void setUp() throws IOException 1 
// location of the excel file 
String filePath - "src/test/resources/Countries.xlsx"; 
// create input stream using file path 
fileInputStream - new FileInputStream(filePath); 
// create the workbook object 
workbook - WorkbookFactory.create(fileInputStream); 
//create a Worksheet by it's index 
workSheet - workbook.getSheetAt(0); ) 


| past the excel file in the ‘resources’ directory. Then | create a class and 3 objects: 


7. Create @Test 


// getSheetName ——» returns the name of the current sheet 
String sheetName = workSheet.getSheetName(); 

// getLastRowNum ——» returns the last row num 

int rowCount = workSheet.getLastRowNum(); 

// getRow(0) ——» get the first row 

// getLastCellNum --» index of last cell(number of columns) 
int colCount = workSheet.getRow(0).getLastCellNum(); 


In order to update excel file we need to change cell value and update 
the excel file. 


Cell colName = sheet.getRow(i).getCell(j) —» target cell 
colName - sheet.getRow(i).createCell(j) — creates a cell 
colName.setCellValue("text") — changes value of the cell 


FileOutputStream fileOutputStream - new FileOutputStream(filePath); 
workbook.write(fileOutputStream); —> to update actual excel file 


fileInputStream. close(); 
fileOutputStream.close(); -> always close streams 


How to write regular expression in testing.xml file to search (9 Test 4 
methods containing "smoke" keyword? 


* Regular expression to find @Test method containing keyword "smoke" is a mentioned 
below 


«methods» 
«include name=".*smoke.*"/> 


</methods> 


What is the use of (QTest(threadPoolSize-somelnteger)? 4 


e The threadPoolSize attribute tells to from a thread pool to run the test method through 
multiple threads 
e Note: this attribute is ignored if invocation count IS NOT SPECIFIED 


» 


What does the test timeout mean in testing? 


e The maximum number of milliseconds a test case should take 


* |n this example: 
- The function Test1 will be invoked 10 times from 3 different threads, 
- Additionally, a timeout of 10 seconds (10000miliseconds) guarantees that none of 
the threads will block on this thread forever. 


CUCUMBER & GHERKIN * 


e What is Cucumber 

e Components of Cucumber BDD framework 
e What is Gherkin 

e Runner Class 


* Report in Cucumber 
* How to see your reports in cucumber? 


e dryRun in Cucumber 
* Hooks in Cucumber 


* Re-run Failed Tests in Cucumber 
* Re-run Failed Tests in JENKINS 


* How do you take screenshots in cucumber 


* Maven Lifecycle 
e POM.xml File 


e Scenario Outline vs Scenario? 

* Page Object Model (POM) 

* Page Factory? 

e @RunWith & @CucumberOptions 


* How to run Cucumber with JUnit? 
* How to run Cucumber with TestNG? 
e How to run a Cucumber with DDT? 


* What is Background? 

e How do | limit the types of variables | can pass? 
* DDT - Data Driven Testing in Cucumber 

* DDT - Data Driven Testing in TestNG 

* How do | use cucumber scenario for DDT? 


* How to use Map in cucumber? 
* How to use POJO in cucumber? 


* EXCLUDE a particular test method from test 
execution 

e Singleton in Framework 

* How does feture file work? 

* Parallel Test in Cucumber 
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What is Cucumber ed 


* Cucumber is a testing tool which is used in Behavior Driven Development. 


* Cucumber works with JUNIT and TESTNG. Cucumber is good for non technical people, 
easy reading, saves time, reusability, maintainable, default report, easy to create smoke 
tests, regression using tags. 


* One of its wonderful main features is the ability to execute plain text functional 
description (written in language named Gherkin) as automated tests. 


* Writing BDD tests in Ubiquitous language, a language structured around the domain 
model and used by all team members including developers, testers, BAs, etc. 


* Cucumber BDD testing tool builds bridges between the technical and nontechnical 
members of a software team. 


* [ ast but not least, Cucumber is an Automated Acceptance Test Tool which running tests 
written in a Behavior Driven Development (BDD) style. 


Components of Cucumber BDD framework? e 


* Feature files 


Consists of scenarios that test a certain feature or functionality 
Feature is main story while scenarios are the test cases to the story(feature) 


* Pages Package 

All the pages in my application are represented in this package. | locate the WebElement in these 
pages. 

* Cukes Runner 

A class that strictly runs the tests, generates codes for step definition @smoketest 

Cukesrunner > IN CUCKESRUNNER I HAVE A FEATURE LOCATION THAT SHOWS WHERE MY 
FEATURE ARE LOCATED 

* Step definition 

A class that made of steps that starts with Gherkin language. Make sure the step definition is in the 
same package as cukesRunner, or child package (not parent or sibling) 


What is Gherkin 


eGHERKIN is a language used by feature files 
eFeature 

eScenario 

eBackGround 

eScenario Outline - Examples 

*Given 

eWhen 

eThen 

eAnd 

But 


» 


Runner Class e 


* | have a runner class that runs my feature files. Using runner class | can 
generate step defs, run certain tests, configure reports etc. 


@RunWith(Cucumber.class) //RunWith comes from JUnit and triggers the execution of the test 
@CucumberOptions( 
plugin = í"html:target/default-cucumber-reports", //to generate report in html format 
"json:target/cucumber.json", //to generate report in JSON format 
"rerun: target/rerun.txt" //this is for the failed test report 


}, 


features = "src/test/resources/com/vytrack/features/", //path to feature file 


glue = "com/vytrack/step_definitions", //path to step definitions classes 

tags = "@wiper", 

dryRun = false //to check the mapping is proper between feature file and step def file. (true, false) 
e ) 


public class CukesRunner 1 


la» 

Report in Cucumber A 

* In my framework | can generate html and JSON reports. My reports have detailed steps 
and the screenshot for failures in the HOOK Class. 


* Default cucumber html reports. —> this is a default reporter meaning | do not need to 
do anything in the pom file to get this. 


We get this report every time when we run the cukesRunner. It does not depend on 
terminal or maven. Even if | run it by right clicking the cukesRunner or clicking on that 
green thingy, we still get the report. 


* maven-cucumber-reporting —> this is a plugin in pom file. | have to add this plugin info 
to my pom file to make it work. We also need to add JSON option into the cukesRunner 
under the plugin. This report shows more metrics, pass, fail rates, enables sorting by tags. 


* To generate this plugin we always have to run using terminal or maven 


Next: Maven Cucumber Report 


Report in Cucumber e 


Maven cucumber reporting — third party open source reporting tool 
for cucumber. Provides better interface and more metrics about the 
test results. 

1. Add new plugin option to CukesRunner 


plugin = 1 "html:target/default-cucumber-reports", 
“json:target/cucumber.json"}, 


. Add the plugin to pom file 
https: //github. com/damianszczepanik/maven-cucumber-reporting 

. Make sure name of the json file matches one provided in param 
<param>**/cucumberx. json</param> 

. Make sure name of the runner matches one provided in include 
«include»:*«/CukesRunner. java</incLlude> 


Run mvn verify in IntelliJ terminal every time we need a 
report (not generated if we run from IntelliJ) 


WR U N 


Cucumber 4 supports parallelization out of the box.It does it using 
maven plugin: maven-surefire-plugin 

<include>**/runners/xParallelRunnerx*. java</include> 
Include tag provide names of classes we want to run. 


A 


How to see your reports in cucumber? 


e Our Cucumber BDD framework generates default HTML reports. 
e The report shows the pass/fail coverage for feature files, tags, steps 
e The report contains all the steps for each test. The report has screenshots 


for failures 

e My framework generates cucumber reports in the target folder which 
contains the reports. When we run the tests on Jenkins, Jenkins saves the 
report of every run. Home page of the Jenkins job always points to the last 
run reports. All the reports for previous runs can be found under the build 


number. 


Go to target folder 


Open with system explorer 
Go to target>cucumberreport>index shows the tests you ran 


dryRun in Cucumber e 


e dryRun is used when we want to generate step definitions without actually 
running tests. If it is true, browser will not open, only the codes will be 
executed. 


Hooks in Cucumber A 


What are Hooks in cucumber? 
e Cucumber hook allows us to better manage the code workflow and helps us to reduce 
the code redundancy. We can say that it is an unseen step, which allows us to perform 
our scenarios or tests. 
e Class that uses 
- @Before > runs before each cucumber scenario 
- (OQ After > runs after each scenario (It will always run no matter if scenario passes or 
fails) 
e Hook Class must be in same package as stepDefinition 
e | implemented SCREENSHOTS inside HOOK class 
e Hook Class will not run if dryRun=true 
e | use Scenario as a parameter in my before/after method 


How do you take screenshots in cucumber? 


How do you take screenshots in cucumber? 
e In my @Aftermethod | have a code: 

e | use TakeScreenShot interface 

e You can store screenshot as a byte or file 


How to generate screenshots —> add Scenario object as a parameter to 
the After hook method. Using this object we check if scenario passed/ 
failed. If failed we adding the screenshot to html report. 


@After () 
public void tearDown(Scenario scenario) { 
// check if scenario failed 
if (scenario.isFailed()) { 
// take the screenshot 
final byte[] screenshot = ((TakesScreenshot) Driver.get()).getScreenshotAs(OutputType.BYTES) ; 
// attach the screenshot to the report 
scenario.embed(screenshot, "image.png"); } 
Driver.closeDriver();])| 


Re-run Failed Tests in Cucumber A 


e We have to report all the failed tests using rerun option. When we run tests, all the failed 
scenarios will be reported in the rerun.txt file. 


e | create another FailCukesRunner class will only runs tests listed in the rerun.txt file. 


e | add both of the runners in the pom.xml file and run tests using maven from terminal. 
Then my pom file runs the main CukesRunner first, after that it runs the failed test runner 
second. 


e We use the re-run option in the CukesRunner. 
- | add the rerun to cukesRunner. 
- This option will create a file with a list of failed tests 
e | create a second runner class which points to file with a list of failed tests 


e | add the second runner in the pom file 


Re-run Failed Tests in JENKINS 


* |n Jenkins there are plugin that re run the failed tests Unit cases. 
* So you can configure your Maven build execution on Jenkins using the option: 


Dsurefire.rerunFailing TestsCount-2 


» 


Maven Lifecycle 


Different Phases in Maven Build Lifecycle 


validate Validate the project is correct and all necessary information is available. 
compile Compile the source code of the project. 


test 


Test the compiled source code using a suitable unit testing framework. 


package Take the compiled code and package it in its distributable format. 


verify 


install 


deploy 


Run any checks on results of integration tests to ensure quality criteria are met. 


Install the package into the local repository, for use as a dependency in other 
projects locally. 

Copy the final package to the remote repository for sharing with other 
developers and projects. 


» 


POM.xml File A 


* A file that manages the whole project 


e When you run a maven command, everything should be done through the 
pom.xml 


Scenario Outline vs Scenario? e 


e Scenario in cucumber runs once. 


* Scenario Outline is used for data driven testing 
Have the same cucumber steps but we provide data after the scenario as a 
table using keyword EXAMPLES 


Page Object Model (POM 


> What is POM (Page Object Model)? 


What are it's advantages? 


* Page Object Model is a design pattern to create Object Repository for web UI elements. 
* Each web page in the application should have corresponding page class. 


*  Pageclass will find the WebElements of that web page and also contains Page methods which perform operations on 
those WebElements. 


Advantages:- 
* Keep operations and flows in UI separate from Verification - clean &easy to understand code 
* Object Repository independent of Test Cases - multiple tests use same Object Repository 

.*  Reusability of code J 


Page Factory? A 


Page Factory is an inbuilt Page Object Model concept for Selenium WebDriver which is 
very optimized. 

It allows separation of Page Object Repository and Test Methods. 

Page Factory class is a class that is used to initialize the page object classes. 

It provides @FindBy annotation to find the WebElements. 


Without using the PageFactory.initElements, page object class with not work as 
expected, for example @FindBy will not work. 


constructor --» | Public NavigationBar() { 


PageFactory.initElements(Driver.get(), page: this); 


(Q0 RunWith & @CucumberOptions e 


@RunWith(Cucumber.class) //RunWith comes from JUnit and triggers the execution of the test 
(9 CucumberOptions( 
plugin = ("html:target/default-cucumber-reports", //to generate report in html format 
"json:target/cucumber.json", //to generate report in JSON format 
"rerun:target/rerun.txt" //this is for the failed test report 
b 
features = "src/test/resources/com/vytrack/features/", //path to feature file 
glue = "com/vytrack/step definitions", //path to step definitions classes 
tags = "(Qwiper", 
dryRun = false //it can be true or false. When dryRun=true, Hook Class and any browser will 
not run. 


e Just like TestNG was providing Groups to run specific test cases together, Cucumber gives that option using Tags. 


) e We can tag scenarios like @Smoke, (9 Regression, @CustomName 
: o @Regression @Smoke 
public class CukesRunner { o Scenario: Add item to cart 


o Given | am on homaepage 
e We can add multiple tags to one scenario 
e We can run scenarios that have any of the mentioned tags (OR logic): 
} o tags = {"@search, @smoke" } 
e We can also run scenarios that have all the mentioned tags. (AND logic): 
o tags = {"@search", "@smoke"} 
o Difference: each tag is in its own “” quotes. 
e We can also ignore running certain tags 
o tags = {"@regression" ,"~@wip"} 


How to run Cucumber with JUnit? 


How to run Cucumber with JUnit? 
e Add cucumber JUnit dependency 
e Adding @RunWith (Cucumber.class) on top of cukesRunner class 


» 


How to run Cucumber with TestNG 


How to run Cucumber with TestNG? 
e Add cucumber TestNG dependency 
e Make CukesRunner extend to AbstractTestNG CucumberTests 


How to run a Cucumber with DDT? e 


* | use Cucumber tables and also Scenario Outline with Examples: 
| Home | Emails | Documents | Projects | 
* You get the method with (DataTable arg1) 
°. |n the parameter DataTable you can change it to 
Liste YourType», List<List<E>>, List<Map<K,V>>, and Map«K, V» 
* Prints in order for list 


" No order for map Feature: Login as different people using maps 
@wiper 
Scenario Outline: Verify title 
Given I login using these credentials 
| username | <username> | 


| password | <password> | 


When I navigate to "Customers" "Contacts" 
Then the page title should be "All - Contacts - Customers" 
Examples: 
username | password | 
| salesmanager101 | UserUser123 | 
| salesmanager102 | UserUser123 | 
| salesmanager103 | UserUser123 | 


What is Backgroun? 


* Cucumber has their own before method 

* [he one in hooks is for java 

* Astep that runs BEFORE a scenario inside the feature file 

* Can only put on top, before all scenarios 

* Cannot put pipelines in backgrounds (Only in scenario outline) 


Feature: User account information 
Background: 


Given I login as a "driver" 
And I navigate to "Customers" "Contacts" 


Scenario: test with manager 
When I click on customer with email "odugmoreb5(üsakura.ne.jp" 


Then customer email should be “odugmore5@sakura.ne.jp" in the account page 


Scenario: test with admin user 


When I click on customer with email "mbrackstone9(iexample.com" 
Then customer email should be "mbrackstone9@exampLle.com" in the account page 


» 


How do I limit the types of variables I can pass? 


e |n the gherkin parenthesis you can add (Collaboration | Sales | Marking, etc.) 
e Ex: 
(0 When("^l hover over the (Collaboration | Sales | Marketing | Activities | All ) menuS") 


public void i hover over the Collaboration menu(String menu) ( 
switch(menu) { 
case "Sales": 
BrowserUtils.hover(dashboard.sales); break; 
case "Marketing": 
BrowserUtils.hover(dashboard.marketing); break; 
case "Collaboration": 
BrowserUtils.hover(dashboard.collaboration); break; 
case "Activities": 
BrowserUtils.hover(dashboard.activities); break; 
case "All": 
BrowserUtils.hover(dashboard.all); break;); 


What if you have a scenario that has two parameters (limiting 4 
parameter, table parameter)? 


e Example: 
o Scenario: Verify Collaboration menu options 
o Given! logged into suiteCRM 
o  Whenlhoveroverthe Collaboration menu 
o Thenthefollowing menu options should be visible for Collaboration: 
| Home| Emails | Documents | Projects | 
o |nthis scenario i have a table, | want to limit collaboration to just collaboration and the other menus categories 
e Solution: 
o @Then("“following menu options should be visible for 
( Collaboration | Sales | Marketing | Activities | All ):$") 
o public void following menu options should be visisble for Collaboration(String menu, List<String> options) { 
o String menu represents the 5 menu options ( Collaboration | Sales | Marketing | Activities | All ) 
List«String»options represents the tables; | Home | Emails | Documents | Projects | 


» 


DDT - Data Driven Testing in Cucumber 


* Test data is separated from code and stored into external sources: 

- Cucumber Examples table 

- Excel files, CSV files 

- Database 
e If the amount of data is not that huge, then | use Cucumber Scenario outline with 
Examples table. 
e And other times | maintain test data in Excel files, and | use Apache POI library to 
read and write data 
e |f data comes from a database, or | need to do database validation, | use SQL 


queries along with JDBC library in java. 


Data Driven Testing 

e WHEN: Whenever a functionality or a module in an app requires testing with multiple sets of data(Parametrization), 
Multiple inputs then we need to perform data driven testing and automation. 
These scenarios are one of the things That must be automated. 


HOW: Test data is separated from code and stored into external sources: Cucumber Examples table, Excel files, CSV 
files, Database. 
BENEFIT: More organized, Data centralized, Collaboration on test data - it can come from BA, MTsetc| 


DDT - Data Driven Testing in TestNG e 


e By using (9 DataProvider annotation, we can create a Data Driven Framework 


@DataProvider(name="getData”) Public Object[][] getData(){ Object [][] data = new Object[2][2]; 
Data[0][0] = “firstUid”; Data[0][1] = "FirstPWD"; 

Data[1][0] = “SecondUid”; 

Data[1][1] = "SecondPWD"; Return data; } 


Extra Information: 


Data Driven Testing 

e WHEN: Whenever a functionality or a module in an app requires testing with multiple sets of data(Parametrization), 
Multiple inputs then we need to perform data driven testing and automation. 
These scenarios are one of the things That must be automated. 


HOW: Test data is separated from code and stored into external sources: Cucumber Examples table, Excel files, CSV 


files, Database. 
BENEFIT: More organized, Data centralized, Collaboration on test data - it can come from BA, MTsetce| 


How do | use cucumber scenario for DDT? 4 


e |n my current project | use Scenario Outline with Examples 
* |n my scenario feature file, whenever I’m using a «variable» as a data driven, | 
use “<variable>” 


: Then in Examples: Feature: Login different types of users 
Examples: Scenario Outline: Login as different users 
| variable! -> column name A 
When I logout 
| data1 | -> row] Then the page title should be "Login" 
| data2 | -> row2 
| data3 | -> row3 Examples: 


| user | 
driver | 


sales manager | 
store manager | 


How to use Map in cucumber? 


bd Using a nonScenario Outline 
. Scenario: Create contact using a map 
o  Givenllogged into suiteCRM 
o  Whenlcreate a new contact: 
| first name | John | 
|last name | Smith | 
| cell phone | 801 888 8889 | 
o Then I should see contact information for "John Smith" 
o  Leftside is key, and right is value 2 columns only 
* Using a Scenario Outline 
o Scenario Outline: Create contact using a map 
o  Givenllogged into suiteCRM 
o  Whenlcreate a new contact: 


| first name | «first name» | 
|last name | <Iname> | 
| cell phone | «cell phone» | 


| office phone  |-office phone» | 
o Then! should see contact information for "—first name» <Iname>" 


o Examples: | first name | Iname | cell phone | office phone | 
| Michael | Jackson | 1234567890 | 2345678891 | 
| Bonnie | Garcia | 4569871234 | 4567890987 | 


- In step def I write; 


Qgwhen("^l create a new contact:$") 
public void i create a new contact(Map«String,String»contact) { 
// open the create contact dialog 


How to use POJO in cucumber? 


- | Create contactBean class 
o I Add all private variables 
o I Add the getter/setters methods 
* | Create bean feature file 
* | Create a table with first row containing the variables in the contactBean class 
o I Add values under the table 
o I Implement method with parameter (List<ContactBean>contacts) 
* | write the Scenario: Create contact 
o Given | logged into suiteCRM 
o When | save a new contact: 
| firstName | lastName | officePhone | cellphone I email | 
| Metin | Kaya | 3456758888 | 1234329999 | metinKaya@gmail.com | 


o Then|should see contact information for "Steve Gates" 


» 


How to EXCLUDE a particular test method from test execution? @& 


* By adding the exclude tag in the testing.xml 


«classes» 
«class names"TestCaseName"» 
«methods» 
«exclude nameb"TestMethodNameToExclude"/» 


«/methods» 
«/class» 
«/classes» 


Singleton in Framework e 


import ... 
//Singleton class is used to create unique driver. 


//To create a singleton class pathern, we need to do following steps: 


// 1. Declare constructor of class as private so that no one instantiate class outside of it. 

// 2. Declare a private static reference variable of class. Static is needed to make it available globally. 

// 3. Declare a static method with return type as object of class which should check if class is already instantiated once. 
e 


public class Driver 1 


private Driver() {} //1. Declare constructor of class as private so that no one instantiate class outside of it. 
private static WebDriver driver; // 2. Declare a private static reference variable of class. 


public static WebDriver get() { //3. Declare a static method with return type as object of class 
if (driver == null) { 
String browser = ConfigurationReader.get("browser"); 
System.out.println("browser = " + browser); 
switch (browser) { 
case "chrome": 
WebDriverManager.chromedriver().setup(); 
driver = new ChromeDriver(); 
break; 
case "chromeHeadless": 
WebDriverManager.chromedriver().setup(); 


driver = new ChromeDriver(new ChromeOptions().setHeadless(true)); 
break; 


How does feture file work? 


e Feature — description of what is being tested. 
o @tags, Sample feature file 
o Background runs before both of the scenarios 


e Scenario — description of the scenario being test 
o Given | am on the login page 
o And | enter username and password 
o When | click on the submit button 
o Then I should be able to see the Dashboard page 


e Given — a precondition 
e When — condition that triggers the expected result 
e [hen —> expected condition 


» 


Parallel Test in Cucumber A 


e | use maven-surefire-plugin. This plugin executes tests in parallel. In this plugin 
configuration, we indicate which runner files we want to run. We can also indicate 
how may simultaneous tests we want to run. 


«include»** /runners/*TestRunner*.java«/include». > plugin will run these files 


«threadCount»10«/threadCount» > this shows how many browsers we want to have in at the same time. 
«parallel»classes«/parallel» > this line tells that cukes runner classes must run in parallel 


How to run? 

* Wecan execute tests in parallel in our framework only by running tests as a maven 
command 

e mvn verify command runs the tests and generate reports 

e mvn clean verify first deletes the target folder, then runs tests, then generates reports 


JENKINS - GIT - MAVEN PN 


JENKINS GIT 
e Jenkins e Git Commends 
* Production Pipeline * Branching Strategy 
* Continious Integration * Merge a Branch with Master Branch 
* Continious Delivery * How to handle Merge Conflict 


* Continious Deployment 
* Create a Job Configuration on Jenkins 
* How many environment do you have? 


Maven 


264/ 


Jenkins ex 


* Jenkins used to automate the processes related to deployment and delivery. 


* Jenkins is application that is hosted in some server. My company uses AWS for hosting jenkins. Our 
Operations (DevOps) team set up the was instance, install Jenkins and other required tools. 

* Pipeline is a set of processes that take the code from version control and compile, build, test and deploy to 
production in automated fashion. 


integration 


smoke regression performance deploy 
test test test 


User acceptance test release 


4 build code analysis unittest test 
Version Test 
control oneironment S Production 
taging environment 


environment 


Continuous Integration 


Continuous Delivery 


[Continuous Deployment] 


mj 


Production Pipeline 


Production Pipeline e 


* Pipeline is a set of processes that take the code from version control and compile, build, test and deploy to 
production in automated fashion. 


* The pipeline breaks down the software delivery process into stages. Each stage is made of different tasks 
which can be carried out in parallel. When all tasks in a stage passes, next stage is triggered. 
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test test test User acceptance test release 
i | D 
: u 3 
" 3 4 


Version 
control Test A 
environment : Production 
Staging environment 
environment 


; integration 
4 build code analysis | unit test test 


Continuous Integration 


Continuous Delivery 


[Continuous Deployment] 


Production Pipel 


mj 


Ine 


Continious Integration e 


* Continuous Integration is an automated build and execution of at unit and integration tests, 
performing code analysis. 


* The Continuous Integration process is comprised of automatic tools that assert the new code's 
correctness before integration. It reduces integration problems allowing to deliver software more 
rapidly by providing quick feedback every time new code is added to the source control. Usually 
Continuous Integration does not involve testing the functionality of the application. 


User acceptance test release 4 


A ^ smoke regression performance deploy 
integration 
4 build code analysis unittest test test test test 
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Version 
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Continuous Integration 
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Continious Delivery e 


* Continuous Delivery is an automated build and execution of at unit and integration tests, 
performing code analysis, functional tests and also deploying to any supported platform any time. 
Each time a build or a set of code passes the tests, it's automatically deployed out to a staging 
environment. In Continuous Delivery releasing to end users is a manual process. Continuous 
delivery involves human decision-making when it comes to deciding when to release the software 
to the customers. 
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Continious Deployment e 


* Continuous deployment means that every change that you make, goes through the pipeline, and if 
it passes all the tests, it automatically gets deployed into production. 


e When a developer checks in code, the automated processes take the code and move it through 
the entire lifecycle and if it passes each gate, it gets deployed directly to production. The delivery 
speeds are notably faster due to elimination of manual steps. 

User acceptance test release E 
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Create a Job Configuration on Jenkins? A 


As a test engineer | only configured my smoke tests on Jenkins. | have a cucumber + junit+ maven framework. First | click 
the New Item link and | write the name of the test, such as smoke-test. 


1. Source Code Management Section 
here we specify where to get the code from. we put the link to our GitHub repo and also enter the credentials 
2. Build Triggers 


| specify how often I run those tests. | choose Build periodically because | want to run in certain schedule. In my project, 
| run smoke tests every morning at 6 am. So in the build trigger | entered daily option: 


H 6 * * * --> every day 6 in the morning 
3. Build Section 


Here | enter the details of the actual run. Since my project is based on maven, | choose option: invoke top-level maven 
targets then | choose which maven to run from the version dropdown. In the next field, | enter the maven goal: test. In 
this field we do not need to enter the word mvn. | also mention here which tag | want to run. So the command will be: 


test -Dcucumber.options="--tags @smoke" 
4. Add Post-build Actions 


In the post build actions, | configure what | want to to after the ends. After each test | generate report and email to my 
team members. 


For Report, | select cucumber reports plugin from the post-build actions to generate reports. 
For email, | select Editable Email Notification option from the Post-build Actions to send emails to my team. 


How many environment do you have? 


e 1. Dev enviroments 
e 2. OA/Test enviroment- this is where | test 
e 3. Staging enviroment 


e 4. Production 


1.Dev Environments - developer work 
2.QA Environments > SDET and manual tester work 


3. Stating/ pre-production Environments > regression test 


4. Production Environments real user use 
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Git Commends 


e „Or create a new repository on the command line 

* gitinit 

* gitadd. 

* git commit -m "first commit" 

e git remote add origin https://github.com/metinkaya1511/FinraDeck.git (GitHub’daki adres) 

* git push -u origin master 

e push an existing repository from the command line 

e git remote add origin https://github.com/metinkaya1511/FinraDeck.git (github adresi) 

* git push -u origin master 

CREATE BRANCH 

- git branch develop ==> it creates new branch named 'develop' but still keep being on master branch 

- git checkout develop ==> it will change your branch to the develop branch 

- git checkout -b develop ==> it creates also a branch named develop and switches to it automatically 

DELETE 

- git branch -d «branch name» deletes the branch. If we have unmerged changes, this command gives a warning and does not delete. 
- git branch -D «branch name» deletes the branch even if it has unmerged changes. Gives no warning. 

SWITCH to Branch 

- git checkout develop checks out the branch, switches to the branch. 

- git checkout -b «branch name» creates a new branch and switches to it. 

- git merge «branch name» this command takes changes from the given branch, and merges with the current branches we are on. 


Branching Strategy A 


e There is master branch and separate branches for each team member. when someone finishes work, they 
push to their own branch, then after reviewing it is merged to master. 


e HOW WE DID IT? 


* |n my project we had master, develop and branch for person. so, if we have 2 automation testers, we will 
have: 

- Master 

- Develop 

- Tester1 

- Tester2 

- Tester3 
e Each tester checks in to their own branches. Then after reviewing it is merged to develop branch. We merge 
master and develop only once a sprint. 
* |n my project, our code is separate repo from the application code repo. Automation framework have a 
smaller code base and fewer people involved. So, we can have less complicated branching policy. 
My daily automated smoke from Jenkins runs against the master branch. Master branch is stable since we only 


merge to with once a sprint. 


How to Merge a Branch with Master Branch Â 


- First we have to come in the branch which we want to merge the codes in. It means generally 
we should come into master branch in this case. 


- git checkout master ==> now you are in master branch 

- git pull origin master ==> We are pulling recent code from master branch on GitHub 

- git merge develop -m "your message here" ==> to merge a develop branch into master branch 
- git add. 

- git commit -m "final commit" 

- git push origin master 

- now when other team members pull master they will see what you sent 


*** git rebase LoginFeatureBranch ==> This will merge Login with Master but closes the 
LoginFeatureBranch for good (completely). 


How to handle Merge Conflict 


git stash -- » take my project to temp memory 
git pull -- » pull the project from GitHub to working directory (my computer) 


git stash pop -- » take my project to my working directory, 
fix the conflict and merge the project. 


git add. 
git commit —m "comment" 


git push 
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Maven e 


* MAVEN is a project build tool for java projects. (There are other build tools for java such as Gradle and Ant) 
* MAVEN automates the process of creating, managing dependencies, compiling, testing, deploying java 
applications. 

* Pom.XML file always located on home folder of the project. Maven automates the build process of Java 
projects. Each phase in the build process is known as a Maven lifecycle or a Maven goal. 


* Maven is also responsible for dependencies. We have to download and add all .jar files we need for project if 
don't use Maven. Maven automatically downloads and adds into project. Dependencies helps us to easily add 
libraries and make project independent from IDE. We can run tests without IDE. (Jenkins execute tests by using 
Maven, not any IDE) 

* Maven Default Lifecycles: 

.] clean - remove all files generated by the previous build (deletes Target file) 

.] validate - validate the project is correct and all necessary information is available 

.] compile - compile the source code of the project 

.] test - test the compiled source code using a suitable unit testing framework 

L verify - run any checks to verify the package is valid and meets quality criteria 

.] package - converts built project into distributable version such as .jar or .war 

.] install - Install the built artifact into the local repository. 

.] deploy - Deploy the built artifact to the remote repository. 


AWS - JMETER - LINUX e 


AWS JMeter 


AWS — EC2 and S3 
AWS — IAM — RDS — Lambda 
AWS — Cloud Formation-AutoScaling Group —Load Balancer 


Linux 


AWS - Cloud Deployment Model 
AWS - Type of Cloud Computing 
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AWS — EC2 and S3 


* |n terms of AWS capability, we use in our company: 


- for Running application for different environments(Test, Dev enviroments). 


- and also for Running Jenkins or any other application for testing purpose. 
- and to Run load testing on the application. 

- It is Used for file storage, test data storage. 

- It Can be used for part of data processing workflow. 


- and also it Can also be used as code repository. 


Continue -> 
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AWS — IAM —- RDS - Lambda e 


d IAM (Identity and Access Management) is a web service that helps you securely control 
access to AWS resources. You use IAM to control who is authenticated (signed in) and 
authorized (has permissions) to use resources. 


- | use IAM for Permission control of users, applications, typically not configured by 
application team but by a cloud team. 


- is Used for database, launch database for different environments to support the 
application. 


- Serverless service that can provide quick and easy solution to run your code without the 
involvement of EC2. 


- Typically used for data processing incoming files. 


Continue -> 


AWS — Cloud Formation-AutoScaling Group —Load Balancer 


A 


- Used for launching application servers and all related AWS services. It is 


also usually called infrustructure as code. 


- Used for scaling servers based on the server load. 


- Used for balancing incoming traffic across multiple servers. 


Continue -> 


AWS - Cloud Deployment Model 


Cloud Deployment Model 
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PUBLIC CLOUD HYBRID ON-PREMISES 
everything is the cloud or combination of on-premise and everything is in your own data 
migrated to the cloud cloud center, 
Cloud Deployment Model 
Cloud Deployment Model Cloud Deployment Model 
) Deploying resources on-premises, using 
A cloud-based application is fully deployed in the A hybrid deployment is a way to connect =, virtualization and resource management tools, is 
cloud and all parts of the application run in the infrastructure and applications between cloud- L sometimes called “private cloud”. On-premises 
cloud. Applications in the cloud have either been A "o deployment does not provide many of the 
ao e sers Das eee S DE MS based e and existing resources that are Poneman a bir sommes 
an existing infrastructure to take advantage of B not located in the cloud. The most common sought for its ability to provide dedicated 
the benefits of cloud computing. method of hybrid deployment is between the resources. 


cloud and existing on-premises infrastructure to 
extend, and grow, an organization's 
infrastructure into the cloud while connecting 
cloud resources to internal system 


AWS — Type of Cloud Computing 


laaS PaaS 


Type of cloud computing Infrastructure as a Service Platform as a Service 


e 


Applications Applications 


Data 
Infrastructure Platform as a Software as a 


as a Service Service Service 


Middleware Middleware 


o/s 


o/s 


Virtualization Virtualization 


Servers Servers 


Storage Storage 


Networking Networking 


SaaS 


Software as a Service 


Applications 


Middleware 


o/s 


Virtualization 


Servers 


Storage 


Networking 


Linux Commands 


Linux Commands (case-sensitive) 

reboot ==> reboots system 

man --» gives you instruction of the command - Ex: 
"man reboot" 

mikdir ==> Creates directory(folder) 

cd ==> Change directory 

Ls ==> List directory content 


pwd ==> Print name of the current working directory. 
It 


gives you the exact location; Ex: /home/Andy/Desktop 
Il ==> Long list format 

Is-la ==> Prints files and hidden file 

clear ==> Clear screen 

cd.. ==> Goes to the parent file (not the root file) 

cd/ ==> Goes to the parent root file 


A 


cd^ ==> Goes to the home of the user file 
grep ==> Prints a line matching a pattern 
df-h ==> Prints the disk space usage top ==> Displays 
linux tasks (like task manager) 
How to create an account: 
- User ==> useradd OK 


- Group ==> groupadd groupName 


* Adding a user into group: 


- useradd -G groupName OK 
- id Andy prints details for this individual (shows it Andy has 


smth...) 


JMeter ed 


* JMeter is a software that can perform load test, performance-oriented business (functional) test, 
regression test, etc., on different protocols or technologies. 

* JMeter is a Java desktop application with a graphical interface that uses the Swing graphical API. It can 
therefore run on any environment / workstation that accepts a Java virtual machine, for example - Windows, 
Linux, Mac, etc. 

The tests that we can execute via the JMeter: 

* Performance Test - This test sets the best possible performance expectation under a given configuration of 
infrastructure. It also highlights early in the testing process if any changes need to be made before the 
application goes into production. 

* [oad Test - This test is basically used for testing the system under the top load it was designed to operate 
under. 

* Stress Test - This test is an attempt to break the system by overwhelming its resources. 


* Even-Odd 


e Swap Numbers 

* Reverse String 

* Reverse Integer 

* Prime Numbers 

e String Palindrome 

* Integer Palindrome 

* Factorial 

e Sum of Digits 

* Fibonacci 

e Find Duplicate Numbers 


N796472229 


e FizzBuzz 


e Only Unique Letters 

e Remove Duplicates 

* Largest Number in Array 
e Armstrong Number 

e Diamond of Asterisks 

e Pyramid Of Numbers 

* Floyds Triangle 


* Anagram 
Count String and Letters 


» 


Even - Odd 


int num = put any number; 
ifínum 96 2 == 0) { 


System.out.println(num + " is even"); 


) else { 
System.out.printIn(num + " is odd"); 


j 


» 


Swap Numbers 


"XzX*y; 
y-x-y; 
X -X-y; 


Duplicate Numbers 4 


public class DuplicateNumbersCount ( // will print duplicate 
numbers 


public static void main(String[] args) { 
int] arr = { 1, 35, 2, 3, 5, 2, 2, 3}; 


int count = 0; 

for (int j = 0; j < arr.length; j++) { 

for (int k = j + 1; k < arr.length; k++) { 
if (arr[j] == arr[k]) { 
count++; 


} 


if (count == 1) 
System.out.println(arr[j]); 
count - 0; 

j 

j 


Count String and Letters 


//Count words 


public static void main(String[] args) ( 
String str = "This Java Casses Are Very Interesting interseting Very Java Are not in the 
class"; 


String[] allWords- str.split(" "); 
HashMap<String, Integer» wordCount = new HashMap«»(); 


for (int i-0; i<allWords.length; i++) { 

if (wordCount.containsKey(allWords[i])) { 

int temp = wordCount.get(allWords[i]); // get getting value only per Vall 
wordCount.put(allWords[i], ++temp); 


} 

else { 
wordCount.put(allWords[i], 1); 
} 

} 


System.out.println(wordCount); 

EE EE EHE HE EHE HE EHE eH HE EHE EHE EHE HE HE Hb) HE E HHHH HE] E HE EHE) HE E E EHE E EHE RH E HR ER À M 4 4- 
// Count letters 

public class CountStringsWithHashMap { 

public static void main(String[] args) ( 

String str = "This Java Casses Are Very Interesting"; 

str-str.replace(" ", "").strip().toLowerCase(); 

HashMap«Character, Integer» letterCount = new HashMap<>(); 

for (int i20; i<str.length(); i++) ( 

if (letterCount.containsKey(str.charAt(i))) { 

int temp = letterCount.get(str.charAt(i)); // get getting value only per Vall 
letterCount.put(str.charAt(i), ++temp); 


else ( 
letterCount.put(str.charAt(i), 1); 
} 

} 


System.out.printin(letterCount); 


Reverse String 


public static void main (String[] args) 1 


"n, 
) 


String word - 
for(int i = word.length()-1; i >=0; i--) { 
System.out.print(word.charAt(i)) 


j 


reverse += str.charAt(i); 
return reverse; can be used in method 


» 


Reverse Integer 


e int num = 1234, reversed = 0; 
while(num != 0) { 
int digit num 96 10; 
reversed = reversed * 10 + digit; 
num /= 10; } 
System.out.println("Reversed Number: " + reversed); }} 


» 


Prime Numbers 


e public static boolean isPrime (int number) 1 


e for(int i22; i < number ; i++) { if(number%i == 0) { 
return false; }} 
return true; } 


» 


String Palindrome 


e for(int iz=word.length()-1;i>=0;i--) { 

e reverse*-word.charAt(i); } 

e if(word.equalslgnoreCase(reverse)) { 

* System.out.println("The word is palindrome’); jelse { 
e System.out.println("The word is not palindrome”); } 


» 


Integer Palindrome 


* public static boolean isPalindrome(int number) { 


* int palindrome = number; 
int reverse=O; 
while (palindrome! = 0) { 
int remainder=palindrome%10; 
reverse = reverse*10 + remainder; 
palindrome = palindrome/10; 
if (number == reverse) { 
return true; } 
return false; 


rh 
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Factorial 


e int number = 10; 
int factorialSum = 1; 
for(int i = 1 ; i<=number; i++) { 
factorialSum = factorialSum * i; } 


e System.out.println("Factorial of " + number +" is " + factorialSum); } 


» 


Sum of Digits 


int number = 1346; 
int sum = O; 
while(number > 0) { 


sum += number%10; 


number = number/10; 
j 
System.out.println(sum); 


j 


» 


Fibonacci 


j 


public class FibinachiNumbers ( 


public static void main(String[] args) { 


int num1=0; // first number is 0 
int num2=1; // 2nd number is 1 


int max=10; // max range of given number 


System.out.printin("First "+max+" Fibonacci numbers"); 
for(int i=O;i<max;i++) { 
System.out.print(num1+" "); 
int sum=num1 + num2; // sum will give us next number in the line 
numi = num2; //1,1,2,3,5,8, 13, 21 
num2=sum; //1 , 2, 3, 5, 8, 13, 21, 34 
j 


FizzBuzz 


public static void main(String[] args) 1 
for(int i = 1; i<=50 ; i++) { 


if (i % (5*3) ==0) { 
System.out.println("FizzBuzz"); 
} else if(i963220)1 
System.out.printin("Fizz"); 
else if(i45==0) { 
System.out.println(" Buzz"); 
else 1 

System.out.println(" " + i); }}}} 


» 


Only Unique Letters 


public static String uniqueChars(String str) | 


String unique = ; 

for (int i = 0; i < str.length(); i++) { 

if (lunique.contains("" + str.charAt(i))) 1 
unique += str.charAt(i); 


j 
j 


return unique; 


j 
j 
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Remove Duplicates @é 


e converting theArrayList to a HashSet effectively removes duplicates 
e Set<String> s = new LinkedHashSet<>(list); 


Largest Number in Array 


e int [] arr = (5, 6, 76, 31, 43, 1}; 
* Arrays.sort(arr); 
e System.out.printin (arr[ arr.length - 1 |); 


» 


Armstrong Number A 


* public static void main(String[] args) { Scanner scan=new Scanner(System.in); 
ae A M a enter number"); int number=scan.nextint(); 
System.out.println(" Please enter number of digits"); 


e int digit-scan.nextInt(); int temp=number; 
int sum=0; 
do { 


e int value = temp 96 10; 
temp /= 10; 
sum += Math.pow (value , digit); 
} while (temp>0); 
if (number==sum) | 
oo heal lalla "This is an Armstrong number"); 
else 
System.out.println("This is not an Armstrong 


e number"); 1H 


Diamond of Asterisks 


Pyramid Of Numbers 


* Scanner scan=new Scanner (System.in); 


e System.out.printlIn("How many rows you want in your pyramid?"); 
int noOfRows=scan.nextint(); 
int rowCount-1; 
System.out.printIn("Here is your pyramid"); 
for(int iznoOfRows;i»0;i--) { 
for(int j=1;j<=i;j++) { 
System.out.print(" “); } 
for(int j=1;j<=rowCount;j++) { System.out.print(rowCount+ " ^); } 
System.out.printin(); 
rowCount++; }}} 


» 


IN 
Floyds Triangle ^ 


Floyd's triangle is the right angled triangle consists of natural numbers in the 
following fashion. 
Floyd's Triangle : 


s 
23 
456 
78910 
1112131415 


public static void main(String[] args) { 


System.out.printIn("How many rows you want in Floyd's Triangle?"); 
Scanner scan = new Scanner(System.in); 
int noOfRows = scan.nextint(); 


int ~ = 1; System.out.println("Floyd's Triangle : "); for(int i=1 ; i<=noOfRows ; 
i++ 

for(int j=1 ; j<=i ; j++) { System.out.print(value+ " "); 

value++; | 

System.out.println(); }}} 


An a g ra i | l What Is Anagram? Two strings are called anagrams if they contain same set of characters 


but in different order. For example, “Dormitory — Dirty Room", "keep — peek”, are some anagrams. 


} 


public static void main(String[] args) { 


String word1 = "abaf "; 
String word2 = "baa"; 


isAnagram(word1, word2); 


static void isAnagram(String s1, String s2) { 


// Removing all white spaces from s1 and s2 String copyOf# 1 


String copyOfs1 = s1.replaceAlll("\\s", ""); 
String copyOfs2 = s2.replaceAlll("\\s", ""); 


5 5 


boolean status - true; 


f (copyOfs1.length() != copyOfs2.length()) { 


status - false; continuation 


else ( 


char[] s1 Array = copyOfs1.toLowerCase().toCharArray(); 
char[] s2Array = copyOfs2.toLowerCase().toCharArray(); 


Arrays.sort(s1 Array); 
Arrays.sort(s2Array); 


status = Arrays.equals(s1Array, s2Array); 


if (status) ( 


System.out.println(s1 +" and " + s2 +" are anagrams"); 
} else ( 


System.out.println("" + s1 +" and " + s2 + " are not anagrams"); 
j 


API 


What is the API What Response includes? Authentication VS Authorization — | 

ECWTDO WE TESTAPIS API TEST STRATAGY HOW TO CONVERTJSON TOJAVA | 
OBJECT? 

What are the and | How do you test rest api? DE-SERIALIZATION / SERIALIZATION | 

API Documentation - Swagger Ways to and Can All API endpoints use all of the 
Http protocols? 

Do you have API documentation | VERIFYING RESPONSE DATA: Difference between and 

Website for your API? RESTful web services? 

| PARAMETERS IN REST SERVICES When I do negative testing End to End Testing Scenarios: UI, 
API, DB 

When to use @QueryParam vs | What when you | TYPES OF BUGS WE FACE WHEN 

@PathParam ? PERFORMING API TESTING 

How do you testrestapi? | CODES - | CHALLENGES IN API TESTING 

CODE 
| What are headers in REST API? What methods are you using to Test flows 
? 
| What Request Line includes? Why do you use JSONPath? My API testing role in my current 


project 


API -> APPLICATION PROGRAMMING INTERFACE! 


CLIENT -> -> -> SERVER(API SERVER) 
CLIENT <- <- <- SERVER(API SERVER) 


CLIENT SERVER 


Request ) 
KAYAK.COM 
R 


esponse 


C# , .NET JAVA 


PLATFORM INDEP 


API is a middle man between database and client. 
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UNITED 


» 
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API Interview Questions 


If API communication happens through internet , we can also call it web service. 


HOW DO WE TEST APIs? 
As we know in API, there is request and response communication happens between 
client and server. 
As testers, we send a request to an API and verify the response. 
Request -» types of requests in RestApi: 
-> GET request -> READ data (like SELECT in sql) 
-» POST request -» is to CREATE data 
-» PUT request -» UPDATE data 
-» DELETE request -» DELETE data 


» 
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What are the Htto methods and request type 


* Get does not requires body 
* (retrieves data from given server using a given URI) 


* Put requires body means UPDATE information 


* (Replaces all current representations of the target resource with the uploaded 
content) 


* Post requires body means CREATE information 
* (send data to the server) 


* Delete does not requires body 
* (Removes all current representations of the target resource given by a URI.) 
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API Documentation - Swagger is a tool for API documentatiot® 


- Swagger is a tool for API documentation. 

- API documentation is a technical content deliverable, containing instructions about how to 
effectively use and integrate with an API. It's a concise reference manual containing all the 
information required to work with the API 


QQ Cybertek School |j Leas x " G Cybertek School | Learn = " * Twitter Developer Piatt x " @ Swagger U! x [5 ara 7.6.1 x © F] selenium jobs in Mctes x Y [7] Bitnami: Open Source. x 4» HomePage | HomePage x [3 Home - Registration C 


a C? © petstore.swagger.io 


Swagger Petstore 9? 


filters. 


pet Everything about your Pets Find out more: : httpz//swagger.io 


S 
| ELE /pet Add a new pet to the store Em 
L | 
| /pet Update an existing pet mh | 
Í 

[ . ENTM z 


/pet/findByTags Finds Pets by tags 
| cer] /pet/{petId} Findpetby!D = 
| | post | /pet/{petId} Updates a pet in the store with form data = 
/pet/{petId} Deletes a pet [1 
frost | /pet/{petid} AU EES AC an image a 


store Access to Petstore orders 
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| ! PN 
Do you have API documentation website for your API? 


e Yes we use swagger for our api documentation and this is where the 
description and guidelines of API endpoints are 


location 
Method where resource resides 
resource 


defines how te access resource URI foo://example.com:8042/over/there?name=ferret#nose 


ge omes 
http://thinkzarahatke.com/author/amty.html#posts URN: 


eel urn:example:animal:ferret:nose 


URI 


- URL(Uniform Resource Locator) ==> https://www.google.com/index.html 
- URN(Uniform Resource Name) ==> www.google.com/index.html 
- URI(Uniform Resource Identifier) ==> https://www.google.com/index.html 


- When we are doing something with API, it means that we are skipping UI and directly get the data/info 


from Web Services. 


2 TYPES OF PARAMETERS IN REST SERVICES: ft 


1) QUERY/REQUEST PARAMETERS 


-> is not part of url and passed in key+value format 
Pose parameters must be defined by API developer 


2) PATH PARAMETERS 


-» is a part of URL and followed by the end of full resource url 
http://34.223.219.142:1212/ords/hr/employees/100 


When to use (QQueryParam vs (Q9 PathParamfk 


e |f there is a scenario to retrieve a record based on id, for example you need 
to get the details of the employee whose id is 15, then you can have 
resource with @PathParam. 


GET /employee/{id} 


e |f there is a scenario where you need to get the details of all employees but 
only 10 at a time, you may use query param 


GET /employee?start-1&size-10 
(This says that starting employee id 1 get ten records.) 


e To summarize, use @PathParam for retrieval based on id. Use 
(0 QueryParam for filter 


How do you test rest api? N 


e | use POSTMAN for manual API testing and use RESTASSURED library 
in Java for automation. 


e | verify if each REST API endpoint is working as expected. 


e | send POST,PUT,GET, DETELE "i of requests and verify response 


status code and response and 
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What are headers in REST API? ed 


*| am using Accept.(ContentType.JSON) type checks what | am receiving 
should be in JSON or XML format 


e | am using ContentType.(ContentType.JSON) checks what | am sending 
should be in JSON format 
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What Request Line includes? 


- end point —> address where we send the request 
- base url where API is 
- resources resources inside baseURL 
- parameters separated from resources with '?'. 
GET —> get some data without changing it in the server. 
- accept type: response in Json or xml 
- authorization tokens, credentials 
POST —> add data to the server. Parameters sent in xml/json as part of 
request body/payload. 
- accept type: response in Json or xml 
- content type: request body in Json or xml 
- authorization tokens, credentials 
PUT —> replaces existing data in the server. 
DELETE —> deletes data. 


// APIs do different types of operations: Create Read Update Delete. 


» 
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What Response includes? 


- Status code —> defines in the request was successful. 
- Header —> metadata (Time of execution, size etc.) 
- Body —> returned information from the server. responses can be in different 


format (Json, XML, text, HTML) 


» 


API TEST STRATAGY e! 


* API testing involves APIs directly and checks whether the API meets 
expectations in terms of functionality, reliability, performance, and security 
of an application. My first concern is functional testing which ensures that 
the API functions correctly. 


* The main objectives in functional testing of the API are: 
* to ensure that the implementation is working correctly as expected - no bugs! 


* to ensure that the implementation is working as specified according to API 
documentation. 


* to prevent regressions between code merges and releases. 
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N 
| HAVE FOUR DIFFERENT PROCESS TO IMPLEMENT ts 


e Checking API contract -SóWAGER: 


An API is essentially a contract between the client and the server or between two applications. Before any implementation test can begin, it is important to make sure 
that the contract is correct. 
e Endpoints are correct, 
* Resource correctly reflects the object model (proper JSON/XML structure used in response), 
e There is no missing functionality or duplicate functionality, 
e Relationships between resources are reflected in the API correctly. 
Now, that we have verified the API contract, we are ready to think of what and how to test. 


° Creating test cases 


| mostly create : 

* Basic positive test (happy paths) 

* Extended positive testing with optional parameters and extra functionality. 

* Negative testing with valid input (trying to add an existing username) 

* Negative testing with invalid input (trying to add a username which is null) 

* Destructive testing (sending null, empty string, integer or other types, odd date format, deleting necessary parameters) 
Security, authorization, and permission tests (sending valid or invalid access tokens to permitted or unpermitted endpoints) 


: Executing test cases 


For each API request | need to verify: 
e | check Data accuracy: | check the request and response body whether those are as written on API documentation in terms of data type and data structure. 
e  |check HTTP status code: For example, creating a resource should return 201 CREATED and unpermitted requests should return 403 FORBIDDEN, etc. 
e  |check Response headers: HTTP server headers have implications on both security and performance. 
e I check Response body: Check valid JSON body and correct field names, types, and values - including in error responses. 
e  |check Authorization checks: Check authentication and authorization 
e  |check Error messages: Check the error code coverage in case API returns any error 
| check Response time: Implementation of response timeout 


e Implementing different test flows 


*  Single-step workflow: 
e Multi 
e Combined API and UI test: -step workflow with several requests: 


» 


How do you test rest api? 


* | also do positive and negative testing of API. 


e When I do positive testing, 
* | send 

* valid request parameters , 

* valid headers, 

* valid request JSON body and 


* verify that response and JSON response body data is also 


* When | do negative testing, 
* | send 


* invalid request parameters , or 
* invalid headers, or 
invalid request json body and 


fv that response 


e veri 


= Ways to navigate JSON and VERIFYING RESPONSE DATA @& 


http: //api.cybertektraining.com/teacher/name/{name} 
{ 


"teachers": [ 


1) Not recommended: 


treat the response json as a String and do contains assertions on it. 
Assertlruelresponse.bodyl.asString().contains("Iava"); 


2) PATH() method. 


, 
": "eniiazov@gmail.com", 


Extract values from JSON using path() method, use Junit assertions for verification. JeinDate : "01/01/2018", 
. . "password": "123456123456", 
String city = "phone": "12345678910", 
assertEquals("New York", city); en ME : 
3) JSONPATH object: "department": "Computer", 


Convert Response data into JsonPath object and use jsonpath getter methods to extract values. Do assertions using JUnit vbisthate x EDU eal 
salary": i 
"batch": 11, 
assertEquals » "section": "1", l 
"premanentAddress": "2700 S. River, Des Plaines, IL 60600" 


4) HAMCREST MATCHERS WITH PATH USING CHAINING: 
We can do assertions in single statement by chaining methods in restAssured. To find values in the json body , we use the same path syntax: 
and().assertThat() 
.body("teachers.firstName",contains("Esen"), 
"teachers.lastName",contains("Niiazov"), 
"teachers.emailAddress",contains("eniiazov@gmail.com")); 
5) Java Collections/Data Structures to manipulate Json Data. JSON RESPONSE --> JAVA DATA STRUCTURE/COLLECTION 


Response Json Data: 


{ 
"year", 2000, 
"make", “Honda” 
"model", "f500", 
"mileage", 50234 
} 


Map<String, Object> dataMa 


=> 2000 
=> Honda 
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VERIFYING RESPONSE DATA: 
1) asString() method convert body to String. treat the response json as a String and do contains assertions on it. 
String responseBody - response.body().asString(); 
assertTrue(responseBody.contains(“Java”); //assertTrue(response.body().asString().contains("Java")); 


2) PATH() method. Extract values from JSON using path() method, use Junit assertions for verification. 
String city = response.path("employee.address.city"); 
assertEquals("New York", city); 


3) JSONPATH object: Convert Response data into JsonPath object and use jsonpath getter methods to extract values. Do assertions using JUnit. 
json.getString(“x”, "y"), json.getInt(a, b).... 

JsonPath json = response.jsonPath(); 

String tName = json.getString("teachers.first name") 

assertEquals("Ayse", tName); //assertEquals("Ayse", json.getString("teachers.first name")); 

long phone = json.getLong("teachers.phone") 

assertEquals(12345678910, phone); 
4) HAMCREST MATCHERS WITH PATH USING CHAINING: We can do assertions in single statement by chaining methods in RESTassured. To find values in the 
json body , we use the same path syntax: 

.and().assertThat() 

.body("teachers.firstName",contains("Esen"), 

"teachers.lastName",contains(" Niiazov"), 

"teachers.emailAddress",contains(" eniiazov(2 gmail.com"); 


5) Java Collections/Data Structures to manipulate Json Data. 
JSON RESPONSE --» JAVA DATA STRUCTURE/COLLECTION 
Response Json Data: 
{ "year", 2000, 
"make", "fiat", 
"model", "f500", 
"mileage", 50234 


}Map<String, Object» dataMap = response.body().as(Map.class);dataMap.get(" year") => 2000 
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When | do negative testing 


* When I send a GET request to REST URL: 

* http://34.223.219.142:1212/ords/hr/employees/1234 
* Then status code is 404 ! 

* And Response body error message is "Not Found" 

* 


@Test 

public void negativeGet() { 
when().get("http://34.223.219.142:1212/ords/hr/employees/1234") 
.then().statusCode(404) ; 

Response response = when().get("http://34.223.219.142:1212/ords/hr/employees/1234")5; 

assertEquals(response.statusCode(),404); 

assertTrue(response.asString().contains("Not Found")); 


) Q3 ^J OQ) UI - UJ IJ LL CQ) X UO ^J OO UI 
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A 


What first thing you check when you get response? 


* Status quote (200 always mean Ok) 
e We always check the 404 means not found 


API STATUS CODES -HTTPS STATUS CODE 


A 


This page is created from HTTP status code information found at ietf.org and Wikipedia. Click on the category heading or the status code link to read more. 


1xx Informational 
100 Continue 


2xx Success 


* 200 OK 

203 Non-Authoritative Information 
206 Partial Content 

226 IM Used 


3xx Redirection 


300 Multiple Choices 
303 See Other 
306 (Unused) 


4xx Client Error 


** 400 Bad Request 

* 403 Forbidden 

406 Not Acceptable 

** 409 Conflict 

412 Precondition Failed 

415 Unsupported Media Type 

418 I'm a teapot (RFC 2324) 

423 Locked (WebDAV) 

426 Upgrade Required 

431 Request Header Fields Too Large 
450 Blocked by Windows Parental Controls (Microsoft) 


5xx Server Error 


*k 500 Internal Server Error 

503 Service Unavailable 

506 Variant Also Negotiates (Experimental) 

509 Bandwidth Limit Exceeded (Apache) 

598 Network read timeout e Lightshot Screenshot 


101 Switching Protocols 


* 201 Created 
* 204 No Content 
207 Multi-Status (WebDAV) 


301 Moved Permanently 
* 304 Not Modified 
307 Temporary Redirect 


* 401 Unauthorized 

* 404 Not Found 

407 Proxy Authentication Required 
410 Gone 

413 Request Entity Too Large 


416 Requested Range Not Satisfiable 


420 Enhance Your Calm (Twitter) 
424 Failed Dependency (WebDAV) 
428 Precondition Required 

444 No Response (Nginx) 

451 Unavailable For Legal Reasons 


501 Not Implemented 

504 Gateway Timeout 

507 Insufficient Storage (WebDAV) 
510 Not Extended 

599 Network connect timeout error 


102 Processing (WebDAV) 


202 Accepted 
205 Reset Content 
208 Already Reported (WebDAV) 


302 Found 
305 Use Proxy 
308 Permanent Redirect (experimei 


402 Payment Required 

405 Method Not Allowed 

408 Request Timeout 

411 Length Required 

414 Request-URI Too Long 

417 Expectation Failed 

422 Unprocessable Entity (WebDA\ 
425 Reserved for WebDAV 

429 Too Many Requests 

449 Retry With (Microsoft) 

499 Client Closed Request (Nginx) 


502 Bad Gateway 

505 HTTP Version Not Supported 
508 Loop Detected (WebDAV) 

511 Network Authentication Requir 


ROOK —— — 
ROLCREATED — 
BODACCEPTED — 
R04 NOCONTENT - 
304 NOT MODIFIED - 
400 BAD REQUEST - 
401 UNAUTHORIZED 


Am|FORBIDDEN — 
404NOTFOUND — 
405 METHOD NOT ALLOWED _ 
409.CONFLICT —————— 
500 INTERNAL SERVER ERROR 
502|BAD GATEWAY 
SOS SERVICE UNAVAILABLE — 
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A 
What methods are you using to verify the size e 
the response data? 


@Test 
public void testItemsCountFromResponseBody() { 
given() .accept(ContentType. JSON) 
.when().get(ConfigurationReader . getProperty(" hrapp .baseresturl")" /regions") 
.then().assertThat() . statusCode(200) 
.and() .assertThat() . contentType(ContentType. JSON) 
.and() .assertThat() .body("items.region_id", hasSize(4)) 
.and() .assertThat() .body( items , region name" , hasIten("Anericas")) 
.and() .assertThat() .body(" items. region name", hasItems("Americas", "Asia", "Middle East and Africa")); 


| use Matchers from Hamcrest 
o hasitem() 
o equalTo() 


326 


Why do you use JSONPath? 


4] "^PIDay3 JsonPatn.java Ls Contiguration.properties = 


Lut 


105 
106 
107 
108 
109 
110 
111 
112 
113 
114 
115 
116 
117 
118 
119 
120 
121 


ann 


"m o 


public void testWithJsonPath() { 


Map<String,Integer> rParamMap = new HashMap<>(); 
rParamMap.put("limit", 100); 


Response response = given().accept(ContentType. JSON)/ /header 
.and().params(rParamMap) //query param/request param 
.andQ) .pathParams("employee id", 177) //path param 


.when().getCConfigurationReader. getProperty("hrapp.baseresturl")-"/emp 


JsonPath json = response.jsonPath(); //get json body and assign to jsonPath object 


System.out.println(json.getInt("employee id")); 
System.out.println(json.getString("last name")); 
System.out.println(json.getString(" job id")); 
System.out.println(json.getInt("salary")); 


JsonPath is used easily to navigate and manipulate JSON data 


B Authentication VS Authorization 


* authentication - who are you? 


* authorization - what rights do you have? 


» 
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` Authentication e 


API KEY - one type authentication, we get it from the service provider (sent to 
account after signing up etc) and we include the key for all our requests as a 
parameter: 


given().queryParam("apikey", "a9faab96"). 


BASIC AUTHENTICATION - using user name and password for authentication 
1. Challenged basic authentication —> rest assured will not send 
username/password initially. It will only be send once server asks for it. 
given().auth().basic(^"username", "password"). 


2. Preemptive basic authentication —> rest assured sends username/ 
password before server asks for it. 


given().auth().preemptive().basic("username", "password"). 
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' Authorization e 


OAUTH Authorization = keys and tokens from 3rd party are used for 
authentication. To get token we are calling get("sign") end point. It requires 
username & password. API recognizes credentials and returns token. 

1. OAuth1 

2. OAuth2 


Response response - given(). 
param("email", "valid email"). 
param("password", "valid password"). 
when().get(endpoint); — to pass credentials 


String accessToken = response.path().get(“accessToken”); —> to get token 


given().header("Authorization", token). —> to use token 


HOW TO CONVERT JSON TO JAVA OBJECT? 


e First in first | add GSON dependency in to the pom.xml file 


«dependency» 
«groupld»com.google.code.gson«/groupld» 
«artifactld»gson«/artifactld» 
«version»2.8.2«/version» 

«/dependency» 


* GSON -> is a json parser that is used to convert 
- from java object to json (serialization) 
- from json to java object (deserialization) 
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DE-SERIALIZATION / SERIALIZATION: ® 


e DE-SERIALIZATION: CONVERT JSON -> JAVA OBJECT 


JSON TO MAP 
17 public class APIDay3_GSON { 
18 
19 @Test 
20 public void testWithJsonToHashMap() 1 
21 Response response = given().accept(ContentType. JSON) 
22 .when().getCConfigurationReader. getPropertyC"hrapp.baseresturL")+"/empLoyees/1 
23 
324 Map<String,String> map =response.as(HashMap.class); 
25 
26 System. out.printLn(map.keySet()); 
27 System. out.printLn(map.vaLlues()); 
28 
29 assertEquals(map.get("employee id"),120); 
30 assertEquals(map.get("job id"), "AC MGR"); 
31 


32 


332 


SERIALIZATION/ DE-SERIALIZATION 


* SERIALIZATION: CONVERT JAVA OBJECT -> JSON 
POST REQUEST 


Country reqCountry = new Country(); 
regCountry. setCountry. id(" TE"); { JSO N } «— — SERIALIZATIOIN 
reqCountry.setCountry_name("A country"); 


reqCountry.setRegion_id(4); 


.and() .body(reqCountry) 


POSTMAN — 
RESTASSURED+JAVA 
=a { JSON } <—— DESERIALIZATIOIN 


’ 


REST API 


CountryResponse resCountry = 
response. body().as(CountryResponse. class 
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Serialization (JAVA to JSON) 
and 
Deserialization (JSON to JAVA format) 


QTest 
public void gSonExample() { 


Gson gson - new Gson(); 
//Serialization: 
Customer customer - new Customer(20, "Vlad", "male", 70339641651); 
customer = {id=20, name=‘Vlad’, gender=‘male’, phone:7033964165] //java format 
String jsonCustomer = gson.toJson (customer) ; 
System.out.println("to json format - Serialization: " + jsonCustomer) ; 
//to json format-Serialization: {"id":20,"name":"Vlad","gender":"male", "phone": 7033964165}  //json format 
//De-Serialization: 


String myJson = "{"id":25,"name":"Roman","gender": "male", "phone" :5712223366}"; //json format 


Customer javaCustomer = gson.fromJson (myJson,Customer.class) ; 
System.out.println("to java format - Deserialization: " + javaCustomer.toString()); 


//to java format-Deserialization: {id=25, name-'Roman', gender-'male', phone=5712223366} //java format 


//fromJson(String json, Which.class) --> it will convert the json to object of the class 
//toJson(java object) -> it will take the java object and create json and return it 
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. 
Can All API endpoints use all of the Http protochts? 


* |t depends, API developer decides if that url works with GET,POST,PUT, or 
DELETE requests 


IN 
Difference between SOAP and RESTful web services? 


e RESTful supports JSON, XML, 

* SOAP supports only XML 

* REST is faster than SOAP based web services 
e SOAP is more secure 

e REST is getting more popular 


N 
End to End Testing Scenarios: UI, API, DB 


* End to End Testing -> Involving Functionality 
End to End Testing -> Involving Functionality Plus Each Layer Of Application 


1) Go to UI -> Add An Employee 
1) Go to DB and verify if employee is added and all data is matching 
2) API -> GET request and verify if employee is added successfully and all data is matching 


-> makes changes in front end and verify in database and REST API. 
2) Go to UI -> add an employee: 

check in UI search page. 
3) POST an employee using REST API: 


1) send a GET request with API and verify 
2) Go to DB and verify if employee is added successfully and all data is matching 
3) Go to front end(website) and verify that data posted is displayed 


-> makes changes using REST API then verify in DB and UI 

4) INSERT an employee into database: 
1) run select statement in DB and verify what you inserted is there in tables 
2) send API GET request and verify JSON is matching data you inserted to DB 
3) Go to front end(website) and verify that data inserted to DB is displayed 
-> make changes in DB using SQL and verify in REST API & front end 


Additional notes @é 


- Big companies use database in a very simple way. Because SQL is very slow 
languages. It doesn't have OOP concept. So, instead of doing manipulation in 
database, companies would rather to do in Web Services. Because they use 
Java, Phython, C++ in web service layer and those are much faster than SQL. 


- JDBC is an API. It is enables Java to interact with the Oracle DataBase. 


- Applications such as Uber and Waze pay some money to google and get the 
permission to access google maps API to use in their own application. This 
communication is provided by API. 


- Or Google use other newspapers to publish news on Google news. Google 
simply connects to these news sources (CNN, Fox, Newyork Times) by using API. 


TYPES OF BUGS WE FACE WHEN PERFORMING API TESTING Â 


* |ssues observed when performing API testing are 
oStress, performance, and security issues 
oDuplicate or missing functionality 
oReliability issues 
olmproper messaging 
olncompatible error handling mechanism 
oMulti-threaded issues 


CHALLENGES IN API TESTING 


e Some of the challenges we face while doing API testing are: 
oSelecting proper parameters and its combinations 
oCategorizing the parameters properly 


O 
à aaa a sonra GET kullanirsan 404 gelir) 
oVerifying and validating the output 


oDue to absence of GUI it is quite difficult to provide input values 


» 
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Test flows e 


We need to implement the next test flow if previous flow is success: 


a.  Single-step workflow: Executing a single API request and checking the response accordingly. Such basic tests are the minimal building blocks we should start with, and there's no 
reason to continue testing if these tests fail. 

b.  Multi-step workflow with several requests: For example, we execute a POST request that creates a resource with id and we then use this id to check if this resource is present in 
the list of elements received by a GET request. Then we use a PATCH endpoint to update new data, and we again invoke a GET request to validate the new data. Finally, we 
DELETE that resource and use GET again to verify it no longer exists. 


No Environment Y o Tt 
GET ... GET .. GET .. POST AX POST A DEL .. DEL... 6 DE PUT + oe 


QD https://rahulshettyacademy.com//maps/api/place/add/json?Key=qaclick123 Save v 


Us i 

"location": { 
3 "lat": -38.383494, 
2 "ing": 33.427362 
32h 

"accuracy": 50, 

"name": "Frontline house", 

"phone. number": "(491) 983 893 3937", 
9 "address": "29, side layout, cohen 09", 
10+ "types": [| 
1 "shoe park", 
1 "shop" 
3. D 
1 "website": "http://google.com", 
15 "language": "French-IN" 


Body Cookies Headers (10) Test Results Status: 200 OK Time: 1171 ms Size: 610 B SaveResponse v 


TQ 


Pretty Raw Preview Visualize SON v 


2 "status": "OK", 
— "e638d4117f81c47t]5c70bf8450086480" , 
4 "scope": "APP", 


5 "reference": "b740b746abae016fa6dca1b4ca292012b740b746abae016fa6dca1b4ca292012" , 
6 "id": "b740b746abae016fa6dca1b4ca292012" 
if 


c. Combined API and UI test: This is mostly relevant to manual testing, where we want to ensure data integrity between the UI and API. We execute requests via the API and verify 
the actions through the UI or vice versa. The purpose of these integrity test flows is to ensure that although the resources are affected via different mechanisms the system still 
maintains expected integrity and consistent flow. 
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My API testing role in my current project N 


As you know I am currently working in a loan company that works with small business companies. 


Once one of our customers wants to apply for a loan from my company, he should create an account using the "get started" button and then they should fill out an online form 


which consists of questions such as firsName, lastName, email, phoneNumber, SSN, etc. All the information is sent to our Database. Our customer can follow and monitor the latest 
status of his application that is pending, accepted or denied using my loan life cycle application. In terms of the API testing, | create all the required information on behalf of the 
customer and using the API POST method | send them to the database. | assert that the relevant information should be also visible at the UA part. Then using API GET, PUT, DELETE 
method I verify that the implementation and end point are working correctly as expected and there are no bugs. For this purpose; 


1. First, | check the API contract which is Swagger to make sure that end points are correct and to ensure that the implementation is working as specified according to 


API documentation (Swagger). 


a. 


2. Then | execute my API test via the POSTMAN; 
3. | write my Test Cases in the feature file using the Gherkin language. 


| mostly create the following test case groups: 


Basic positive test 


b. Extended positive testing with optional parameters and extra functionality. 


b. 
d. 


e. 


f. 


Negative testing with valid input (trying to add an existing username) 
Negative testing with invalid input (trying to add a username which is null) 
Destructive testing (sending null, empty string, integer or other types, odd date format, deleting necessary parameters) 


Security, authorization, and permission tests (sending valid or invalid access tokens to permitted or unpermitted endpoints) 


e 4. For each API request | need to verify that; 


a. 
b. 


C. 


m ^02 


| check the request and response body whether those are as written on API documentation in terms of data type and data structure. 

| check HTTP status code. For example, creating a resource should return 201 CREATED and unpermitted requests should return 403 FORBIDDEN, etc. 
| check Response headers. HTTP server headers have implications on both security and performance. 

| check Response body. | check valid JSON body and correct field names, types, and values, including in error responses. 

| check Authorization checks. | check authentication and authorization 

| check Error messages. | Check the error code coverage in case API returns any error 


| check Response time. 


SQL (Structured Query Language) 


What is SQL? 

What is a Database? 
RDBMS? 

Subsets / Categories of SQL? 
SQL vs MySQL 

Database Schema 

DML and DLL Commands 


Primary Key and Foreign Key 
Primary Key vs UNIQUE 


DISTINCT 


Comparison Operators 
Where, Having, Order By, Group By 


Inner Join 


Outer Join (Left-Right-Full Outer Join) 


Self Join 

Aggregate functions in SQL? 
‘BETWEEN’ vs ‘IN’ condition 

DELETE - DROP — TRUNCATE 
COMMIT — SAVVEPOINT - ROLLBACK 


MetaData 

Views vs Tables 

Char vs Varchar2 data type 

Set Operators(Union-UnionAIl- 
Minus, Intersect) 

Single Row functions(Lower, Upper...) 
Multiple Row Functions 
(Count, MIN, MAX...) 

COMMIT 

Add a COLUMN to a table 

SELECT Rondom Rows from a table 
Order of SQL SELECT 

Copy Data from Table1 to Table2 
Database WHITEBOX and BLACKBOX 
TESTING 

VIEWS 

UPDATE ROW - DELETE ROW 
CREATE TABLE 

INSERT VALUES 

UPDATE VALUE 


QUERY SAMPLES 


SELECT UNIQUE RECORDS 


1st MAX Salary 
2nd MAX Salary 
3rd MAX Salary 


MIN Salary 

Salary below the average 
Names SRART WTH ‘A’ 

MAX salary in each department 
Duplicate value 


Select Unique Records 
Current Date and Time 
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What is SQL? e 


* SQL stands for Structured Query Language. It is the standard language for 
relational database management systems. It is especially useful in handling 
organized data comprised of entities (variables) and relations between 
different entities of the data. 


Web Application Architecture 
Front End Back End 


inen pr preme ipt. PHP, Ruby, Python, 
Boots trap, CoffeeScript C£, Java, Node.js 
Swift and more 
nd more. Angular.js Database adrr 
Fiunt End Doppia BackEnd Developers — se developers 
P Server side developers 


UI UX Designer.. 


- Manual Testing - API Testing - Database Tester 

- Black Box Testing - API Automation - Automate Database 
- Selenium - Test Using JS 

- Protractor - JDBC 


What is a Database? (1) 


* A database is an organized collection of data, stored and retrieved digitally 
from a remote or local computer system. Databases can be vast and 
complex, and such databases are developed using fixed design and 
modeling approaches. 


Database: is a place where data is stored in organized manner. Consists of 
tables. Tables are made of rows and columns. relational: Oracle 11g, MySQL, 
Sybase... non-relational: MongoDb 


RDBMS? e 


* Relational Database Management System (RDBMS) means that tables in 
database are related using primary/foreign key relationship. Used to store, 
modify and retrieve data in the database. 


* How are they related? 
Primary Key (unique and not NULL) 
Foreign Key (duplicate and NULL) 


* What type of database system you have expertise with? 
RDBMS, such as SQL and Oracle 


* Entity Relation Model (ERM): An entity can be a real-world object, that can 
be easily identifiable: student, class, teacher. 


* Attributes: Things that describe the Entity. (student name, age, birthday...) 


Subsets / Categories of SQL? 


i. DML (Data Manipulation Language) 
e  DML statements affect records in a table. These are basic 
operations we perform on data such as selecting a few records 
from a table, inserting new records, deleting unnecessary 
records, and updating/modifying existing records. 
ii. DDL (Data Definition Language) 

e  DDL statements are used to alter/modify a database or table 
structure and schema. These statements handle the design and 
storage of database objects. 

iii. DCL (Data Control Language) 

e  DCL statements control the level of access that users 
have on database objects. 

iv. TCL (Transaction Control Language) 

e TCL statements allow you to control and manage 
transactions to maintain the integrity of data within SOL 

statements. 


SQL vs MySQL e 


e SQL is a standard language for retrieving and manipulating structured 
databases. On the contrary, MySQL is a relational database management 
system, like SQL Server, Oracle or IBM DB2, that is used to manage SQL 
databases. 


DATABASE SCHEMA e 


e DATABASE SCHEMA: is a chart that shows all the tables and how they are 
related to each other. 


° If there is no schema: 
1. Oracle ===> SELECT table name FROM user tables; 
2. MySQL ===> show tables; 


LOCATIONS 
location id 


street address 
postal code 
city 


COUNTRIES 
country id 
country name 
regeon id 
ar 


REGIONS 
region id 
regeon name 
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DML and DLL Commands 


DML command actions can be restored. DDL command actions cannot be restored | undone. 


Commands: Commands: 
e SELECT from tablename; (read) e CREATE table tablename (columna, column? ...); 
e INSERT into tablename values (...); (add) e ALTER table tablename modify value; 


e UPDATE tablename SET value WHERE location; e TRUNCATE table tablename; (delete whole table data) 
e DELETE from tablename WHERE location; (rows) e DROP TABLE; (delete whole table with structure) 
e MERGE e RENAME 

e COMMENT 


What are constraints? 


* Properties that table column must comply with. 


e Columns have constraints that defined how data can be stored. 


* Primary Key: should be unique and NOT NULL 
Foreign Key: can be duplicate and NULL 


e Data which is not in PK 
Unique Key: only unique value 
Null: can have null 
Not null: cannot have null 


» 


A 


Primary Key and Foreign Key 


e |tisunique column in every table in a e |tisa column that comes from a different 
database table and using Foreign key tables are 

* |t can ONLY accept; related each other 
- nonduplicate values * |tisthe primary key of another table 
- cannot be NULL * |tcan be duplicate or null for another 


table 


Primary Key vs UNIQUE N 
*A table can have only one PRIMARY KEY whereas 


there can be any number of UNIQUE constrain. 


*The PRIMARY KEY cannot contain null values whereas 
the Unique constrain can contain null values. 


Data Types in SQL 


e number(num) - whole numbers up to num digits 

e number(num,num2) - num whole numbers up to num2 decimals 
e char(num) - fixed length character/string 

* varchar2(num) - used for varying length data 

* date - full date 

* currency - used for prices 
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DISTINCT 
e SELECT DISTINCT displaying non-duplicate data 


SELECT DISTINCT job id FROM employees; 


» 


Comparison Operators 


between 
SELECT * SELECT * 
FROM employees i emp Loyee 
WHERE salary >= 4000 ERE salary BETWEEN 4000 AND 6000; 


AND salary <= 6000; 


is not operator <> 


SELECT last_name, job_id SELECT last name, job id 
FROM employees FROM employees 
WHERE job id «» 'SA REP'; WHERE NOT job id - 'SA REP'; 


IN operator 


SELECT * SELECT * 
FROM employees FROM employees 
— department id - 90 WHERE department id IN (60, 90); 


OR department id = 60; 


LIKE operator (for partial searches using wildcard ‘%’ * ') 


SELECT * SELECT x 
FROM employees FROM employees 
WHERE first name LIKE ‘Nx’; WHERE last name LIKE ' a*s'; 


top N results 


SELECT * 
FROM employees 
WHERE ROWNUM <=5; 


SELECT NVL(commission pct, 0) 
FROM employees; 


WHERE, ORDER BY, GROUP BY, HAVING a 


SQL clause helps to limit the result set by providing a condition to the query. A clause helps to 
filter the rows from the entire set of records. For example — WHERE, HAVING clause. 

WHERE clause in SQL is used to filter records that are necessary, based on specific conditions. 
WHERE is a row operation. 


SELECT x 

FROM employees 

WHERE first name LIKE 'Ns'; 
HAVING clause in SQL is used to filter records in combination with the GROUP BY clause. It is 
different from WHERE, since WHERE clause cannot filter aggregated records. HAVING is a column 
operation. 


SELECT department id, MIN (salary) 
FROM employees 


GROUP BY department id 
HAVING MIN (salary) < 3500; 


ORDER BY clause in SQL is used to sort the records based on some field(s) in ascending (ASC) or 
descending order (DESC). 

GROUP BY clause in SQL is used to group records with identical data and can be used in 
conjunction with some aggregation functions to produce summarized results from the database. 


Joins 


JOIN (INNER) JOIN 

is used when retrieving data from multiple tables 
and will return only matching data 

LEFT (OUTER) JOIN 

is used when retrieving data from multiple tables 
and will return left table and any matching right 
table records. 

RIGHT (OUTER) JOIN 

is used when retrieving data from multiple tables 
and will return right table and any matching left 
table records. 

FULL (OUTER) JOIN 

is used when retrieving data from multiple tables 


and will return both table records, matching and 
non-matching 


>» SQL JOINS 


SELECT <select lt? 
FROM TabicA A 
LEFT JOIN Tabie B B 
ON A Key = B Key 


0 


SELECT «lect Est 
FROM TableA A 

LEFT JOIN TabloR R 
ON A.Key = B.Key 
WHERE P.Key 18 NULL, 


SELECT cecleet_ia> 
FROM Table A 


FULL OUTER JOIN Tabie B 


ON A Key = B.Kes 


SELECT <select liit 
FROM TabicA A 
RIGHT JOIN TabieR B 
ON A. Key = B Rey 


SELECT <schect_list> 
FROM TableAA 
INNER JOIN Table B B 
ON Aes * B Rey 


SELECT *s»ckxt li» 
FROM TableA A 
RICHT JOIN Tobio B B 


ON A Key = B.Koy 
WHERE A Key I8 NULL 


SULECT 4sclect list 
FROM Tabled A 
PULL OUTER JOIN TableB B 
ON A. Rey = B.Rey 
WHERE A.Key 15 NULL 
CL. Motte ZF OR B.Key I5 NULL 


INNER JOIN e 


INNER JOIN ==> used to display data from multiple tables and returns 
only matching records 


SELECT employee_id, last_name, employees.department_id, department_name 
FROM employees JOIN departments 
ON employees.department id = departments.department id; 


SELECT employee id, last name, employees.department id, department name 
FROM employees JOIN departments 
USING (department id); 


OUTER JOIN (Left Outer-Right Outer-Full Outer) e 


sA R RIGHT OUTER JOIN— used to display data from multiple 
tables and returns matching records and non-matching records from right 
hand side table 

SELECT student_id, student_lastname, c.course_id, course_name 

FROM students s RIGHT OUTER JOIN -> right table 

ON s.course_id = c.course_id; -> right table 

2.2. LEFT OUTER JOIN— used to display data from multiple tables 
and returns matching records and non-matching records from left hand 


side table 


SELECT student_id, student_lastname, c.course_id, course_name 
FROM LEFT OUTER JOIN courses c -> left table 
ON = c.course id; -> left table 


2.3. FULL OUTER JOIN — display data from both tables 


SELF JOIN 


SELF JOIN ==> used to display data from same table 


SELECT el.last name, manager id, e2.last name 
FROM employees-el JOIN employees e2 


ON el.manager id - e2.employee id; 
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Aggregate functions in SQL? 


* SQL Aggregate functions determine and calculate values from multiple 
columns in a table and return a single value. 


* There are 7 aggregate functions in SQL: 
- COUNT() : Returns number of table rows. 


- MAX() 
- MIN() 
- AVG() 
- SUM() 
- FIRST() 
- LAST() 


: Returns the largest value among the records. 

: Returns smallest value among the records. 

: Returns the average value from specified columns. 
: Returns the sum of specified column values. 

: Returns the first value. 

: Returns last value. 
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‘BETWEEN’ vs ‘IN’ condition operators? e 


e BETWEEN operator is used to display rows based on a range of values in a 
row whereas the IN condition operator is used to check for values contained 
in a specific set of values. 


* Example of BETWEEN: 


SELECT * FROM Students 
WHERE ROLL NO BETWEEN 10 AND 50; 


* Example of BETWEEN: 


SELECT * FROM students 
WHERE ROLL NO IN (8,15,25); 


DELETE vs TRUNCATE vs DROP statements? @ 


* DELETE is used to delete or remove one or more existing row. 


* TRUNCATE deletes all the data from inside a table, but not the structure; 
cannot be retrieved back 


* DROP deletes everything; data, table and structure from the database; 
cannot be retrieved back 


//to delete values 
DELETE FROM students 
WHERE student id = 104; 


'/clears table, keeps the table 
TRUNCATE TABLE students; —> can not be rolled back 
//geletes the tabl 


DROP TABLE studeats: —> can not be rolled back 


COMMIT — SAVEPOINT - ROLLBACK 


* COMMIT —> making all pending changes permanent; 

* SAVEPOINT name —> marks a save point 

* ROLLBACK —> discharges all pending changes to prev commit 
* ROLLBACK TO name —> rolls back changes to savepoint 


Metadata 


* Metadata: data about data. 3 types: 
- Database Metadata 
DatabaseMetaData dbMetaData = connection.getMetaData(); 


- Resultset Metadata 
ResultSetMetaData rsMetaData = resultSet.getMetaData(); 
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Views vs Tables 


e 


A table is structured with a set number 
of columns and a boundless number of 
rows. 


It is a virtual table that is 
extracted from a database. 


Table contains data and stores the data 


Views do not hold data themselves. 
in databases. 


A view is also utilized to query A table holds fundamental client 
certain information contained ina information and the cases of a 
few distinct tables. characterized object. 


In a table, changing the information in 
the database changes the information 
that appears in the view 


In a view, we will get frequently 
queried information. 


CHAR and VARCHAR2 datatype in SQL i 
Both VARCHAR & VARCHAR2 are Oracle data types that are used to store character 
strings of variable length. 
Their differences are: 

e VARCHAR can store characters up to 2000 bytes while VARCHAR2 can store 

up to 4000 bytes. 


e VARCHAR will hold the space for characters defined during declaration 


even if all of them are not used whereas VARCHAR2 will release the unused 
space. 


SET OPERATORS (UNION, UNION ALL, MINUS, INTERSECT 4 


1. Number of columns must be same 
2. Data type should be same 


* UNION (returns combined rows from 2 independent queries and removes 
duplicates and sorts them) 


* UNION ALL (returns combined rows from 2 independent queries but DOES 
NOT remove duplicates or sort them) 


* MINUS (returns records from 1 query that are not present in 2 query) 
* [NTERSECT (returns only common for both queries data) 


Single Row Functions (Lower, Upper, Substr, Length, INITCAP) we 


e Single Row Functions: function that will run for each row and return value 


for each row 
LOWER 


SELECT LOWER (last name) 
FROM employees; 


INITCAP (capital first) 


SELECT INITCAP (last name) 
FROM employees 


INSTR (indexOf 1 based) 


SELECT INSTR (last name, ‘a’) 
FROM employees 


SELECT SUBSTR (first name, 0, 3) 
FROM employees; 


TRUNC 


SELECT TRUNC (commission pct, 2) 
FROM employees; 


UPPER 


SELECT UPPER (last name) 
FROM employees; 


LENGTH 


SELECT * 
FROM employees 
WHERE LENGTH (last name) - 6; 


REPLACE 


SELECT REPLACE(last name, ‘a’, ''b) 
FROM employees; 


ROUND 


SELECT ROUND (commission pct, 89) 
FROM employees; 


MOD 


SELECT * 
FROM employees 
WHERE MOD (employee id, 2) = 9; 


Multiple Row Functions (Count, MIN, MAX, AVG, SUM) 


A 


Multiple Row Functions (Group functions, Aggregate functions): will run for 
multiple rows and return a single value 


SELECT COUNT (x) 
FROM employees; 


SELECT MIN (salary) 
FROM employees; 


SELECT SUM (salary) 
FROM employees; 


count in each department 


SELECT department id, COUNT (x) 
FROM employees 
GROUP BY department id; 


SELECT MAX (salary) 
FROM employees; 


AVG 


SELECT AVG (salalry) 
FROM employees; 


COMMIT € 


e COMMIT saves all changes made by DML statements. 


e The COMMIT command saves all the transactions to the database since 
the last COMMIT or ROLLBACK command. 


Add a column to a table? N 


* To add another column in the table, | write the command like:: 


ALTER TABLE table name ADD column name varchar(50); 


Select RANDOM ROWS from a table 


* Using a SAMPLE clause, we can select random rows. 


SELECT * FROM table name SAMPLE(10); 


» 


» 


Order of SQL SELECT 


Order of SOL SELECT clauses is: 
- SELECT 
- FROM 
— WHERE 
- GROUP BY 
- HAVING 
— ORDER BY 
- Only the SELECT and FROM clauses are mandatory 


COPY Data from one table into another e 


* Let's assume that, we have our employee table. We have to copy this data 
into another table. For this purpose, we can use the INSERT INTO SELECT 
operator. Before we go ahead and do that, we would have to create another 
table that would have the same structure as the given table. 


* First create the second table with the same table structure with copied one. 
* Then use the syntax: 
Let's say employee duplicate is New table 

employee is First table that we want to copy it into new table 


INSERT INTO employee duplicate SELECT * FROM employee; 
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Database WHITEBOX and BLACKBOX TESTING 


e Database White Box testing involves: 
- Database Consistency and ACID properties 
- Database triggers and logical views 
- Decision Coverage, Condition Coverage, and Statement Coverage 
- Database Tables, Data Model, and Database Schema 
- Referential integrity rules 
e Database Black Box testing involves: 
- Data Mapping 
- Data stored and retrieved 
- Use of Black Box testing techniques such as Equivalence Partitioning and 
- Boundary Value Analysis (BVA) 


VIEWS N 


Views are created in order to store your queries as virtual 
table. If there are a lot of columns and we don't want to 
use all columns and make the table simpler, we can create a 
view and reuse it repeatedly. Actually, view does not store 
any data however, it contains the retrieve statements to 


provide reusability. We can create view if we use some 
queries mostly. 


create view EmployeeInfo as 


select first name || last name as "Full Name" 
from employees; 


Does View contain Data? 
No, Views are virtual structures. 


UPDATING ROW - DELETE ROW 


UPDATING ROW 

Update TableName set ColumnName = value where condition; 
update scrumteam set firstname -'Martin' where EmployeeID-'1'; 
update scrumteam set lastname -'Murtin' where firstname='Tom’; 


DELETING ROW 

delete from TableName where condition; 

delete from scrumteam where firstname-'Jack'; 
delete from scrumteam where JobTitle-'SDET'; 


CREATE TABLE 


//to create a table 

CREATE TABLE students 

( student id number(4) primary key, 
last name varchar2(30) NOT NULL, 
course id number(4) NULL ); 


//to insert values 

INSERT INTO students VALUES (200, 'Jones', 101); 
INSERT INTO students VALUES (201, ‘Smith’, 101); 
INSERT INTO students VALUES (202, ‘Lee’, 102); 
COMMIT; —> to save changes 


» 


TO INSERT VALUES 


//to insert values 

INSERT INTO students VALUES (200, ‘Jones’, 101); 
INSERT INTO students VALUES (201, ‘Smith’, 101); 
INSERT INTO students VALUES (282, 'Lee', 102); 
COMMIT; —> to save changes 


» 


» 


TO UPDATE VALUES 


//to update values 
UPDATE students SET course id - 102 
WHERE last name = 'Jones'; -» if there is no conditlion it will update all! 


JDBC e 


* Java Database Connectivity used to connect Databases and any Java applications. 
Provides a call-level API for SQL-bases Database access . Connects Java Program with 
Database. No need to install it. Only dependency for a specific driver to use with your 
Database(Oracle). They are developed by DB manufacturers. Code written for one DB will 
work on another. 


* To connect to database we need driver to work with our database; url for our db 
and credentials. 


onnection —> helps connect to database ResultSet methods: 
Connection connection = DriverManager.getConnection(url, userName, password); 


next() —» moves to next row 
Statement—> helps write and execute SQL query previous() —» moves to previous row 
Statement statement = connection.createStatement i - 
(ResultSet.TYPE SCROLL INSENSITIVE, ResultSet.CONCUR READ ONLY); ge tObjecf(colname/index » reads data from column 
first) —> jumps to first row 


// SQL Injection is a common way of hacking application databases by hackers lasti) —> jumps to last row 
PreparedStatement prepStatement = connection. prepareStatement(query); 


prepStatement.setInt(1, 2); — replaces '?' In our query with number absolute{int ron) => 90 to specific row , , 
beforeFrsi() —> jumps to row 0. Used to call next() method in while loop 
getRow() —> returns index of current row 


ResultSet—> stores data that came from database 
- Forward only 
- Scrollable 


ResultSet resultSet = statement.executeQuery("query"); 
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select unique records from a table? e 


* You can select unique records from a table by using the DISTINCT keyword. 
DISTINCT 
- select distinct * from employees; ==> retrieves any row if it has at 


least a single unique column. 


- select distinct first name from employees; --» retrieves unique names 
from table. (removes duplicates) 


- select distinct count(*) from employees; retrieve number of unique rows 
if any row has at least a single unique data. 


1st MAX Salary 


SELECT MAX(salary) FROM employees; 
e Who is the person getting highest salary 
SELECT first-name 


FROM employees 
WHERE salary = (SELECT MAX(salary) FROM employees); 


» 


2^? MAX Salary 


SELECT first-name , salary 

FROM employees 

WHERE salary = (SELECT MAX(salary) FROM employees WHERE salary NOT IN 

(SELECT MAX(salary) FROM employees)); 

Or KK KK KK KK KKK 

SELECT * FROM employees 

WHERE salary = (SELECT * FROM (SELECT DISTINCT salary FROM employees 
ORDER BY salary DESC) WHERE ROW NUM <=2 

MINUS 
SELECT * FROM (SELECT DISTINCT salary FROM employees 

ORDER BY salary DESC) WHERE ROW NUM <=1); 


» 


3rd MAX Salary 


SELECT * FROM employees 
WHERE salary = (SELECT * FROM (SELECT DISTINCT salary FROM employees 
ORDER BY salary DESC) WHERE ROW NUM <=3 
MINUS 
SELECT * FROM (SELECT DISTINCT salary FROM employees 
ORDER BY salary DESC) WHERE ROW NUM <=2); 


» 


find lowest salaries? 


SELECT first name, last name, salary, job id 
FROM employees 
WHERE salary = (SELECT MIN(salary) FROM employees); 


» 


employees whose salaries are below the average? e 


SELECT first name, salary FROM employees 
WHERE salary <= (SELECT AVG(salary) FROM employees); 


find names of employee start with ‘A’? A 


e SELECT * FROM Employees 
WHERE emp. name LIKE 'A96' ; 


maximum salaries in each department? 


* select deptno, Max(Sal) from emp Group By Deptno 


» 


duplicate names in employees? 


* SELECT first name, COUNT (first name) FROM employees 
GROUP BY first name 
HAVING (COUNT(first name) > 1); 


» 


select unique records from a table? e 


* You can select unique records from a table by using the DISTINCT keyword. 


SELECT DISTINCT names FROM employees; 


CURRENT DATE and time in Oracle? 


SELECT CURRENT DATE from dual; 


AngularJS 


AngularJS is a JavaScript-based open-source 
front-end web framework. 


AngularJS is a structural framework for dynamic 


web apps. It lets you use HTML as your 
template language. 


But the problem is that we spend a lot of time 
updating the document object model (DOM), 
the representation of the HTML that sits inside 
the browser's memory. 


That's the way for us to manipulate the HTML 
and code, and also to read it and see what all 
the HTML on the page is attributes and various 
values. 


So we need to do a lot of management 
ourselves without AngularJS, after a while, this 
gets really difficult to deal with and it can 


A 


become just overwhelming. 


So, with AngularJS, if we could just update one 
side and the other side updated automatically. | 
mean the HTML and JS updates. 


AngularJS is attaching events and looking at 
variables. Every time something changes or 
something even could have changed, it checks 
all those values and then updates the page and 
the other variables for me. 


AngularJS VS NodeJS @é 


* Angular JS is a front-end framework and can be used with any backend 
programming language like PHP, Java etc. whereas Node JS is simply a 
server-side language, in a web application like context it acts as a Java on 
the server side. ... Angular JS runs on the client browser whereas Node 


JS runs on the server side. 


Java Codes 


public static String reverseString(String str) ( 
String reverse= ™; 

for(int i = str.length()-1; i >=0; i--) { 

reverse += str.charAt(i); } 

return reverse; } 


public static void main(String[] args) { 
String str = "Hello World"; 

StringBuilder sb = new StringBuilder(str); 
System.out.printin(sb.reverse()); } 


public void printReverse(char[] letters, int size)( 
for (int i = letters.length-1; i >= O ; i--){ 
System.out.print(letters[i]); ) } 


public static int reverse(int number)( 

int num = 1234; 

Int reversed = 0; 

int digit = 0; 

while(num != 0) { 

digit = num % 10; 

reversed = reversed * 10 + digit; 

num = num / 10; } 

System.out.printin("Reversed Number: " + reversed); } 


=a 


int number = 1346; 

int sum = 0; 

while(number > 0) ( 

sum += number%10; 

number = number/10; } 
System.out.printin(sum);  ) 


int temp = a; 
a= b; 
b = temp; 


if(num % 2 == 0) { 
System.out.printin(num + " is even"); 
) eise ( 

System.out.printin(num + " is odd"); 


int [] arr = (5, 6, 76, 31, 43, 1}; 
Arrays.sort(arr); 
System.out.printin(arr[arr.length-1]); 


public static int getLargest(int[] a, int total) { 
int temp; 

for (int i = 0; i < total; i++) { 

for (int j = i + 1; j < total; j++) { 

if (a[i] > a[j]) { 

temp = a[i]; 

ali] = a[l]; 

alj] = temp;} } } 

return a[total-1]; } 


public void GetTwoMaxValues(int[] nums) ( 

int maxOne = 0; 

int maxTwo = 0; 

Arrays.sort(nums); 

System.out.printin("Max1 - " + (nums[nums.length-1])); 
System.out.printin("Maxz2 - " + (nums[nums.length-2])); 


String str="YollAcademy"; 
char[] arrayzstr.toCharArray(); 
System.out.printin(array.length); 
for (int i=0; i<array.length; i++) { 
System.out.printin(array[i]); } 


String input = "Try to remove extra spaces." 
String inputNew = input; 

while (inputNew.contains(" ")) { 

inputNew = inputNew.replace(" ", ""); ) 
System.out.printin(input); 
System.out.printin(inputNew); 


public static boolean isPrime (int number) { 
for(int i=2; i < number ; i++) { 

if(number%i == 0) 

( return false; }} 

return true; ) 


public static void main(String[] args) ( 
for(int i = 1 ; i<=50 ; i++) { 

if ( i 9o (5*3) == 0) { 
System.out.println("FizzBuzz"); 

) else if(i%3==0) ( 
System.out.printin("Fizz"); 

jelse if(i%5==0) { 
System.out.printin("Buzz"); 

jelse { 

System.out.printin(i); } } ) ) 


STRING PALINDROME 

for(int i=word.length()-1;i>=0;i--) { 
reverse*-word.charAt(i); } 
if(word.equalsignoreCase(reverse)) { 
System.out.printin("The word is palindrome”); 
jelse { 

System.out.printin("The word is not palindrome”); 


public static boolean isPalindrome(int number) { 
int palindrome = number; 

int reverse=0; 

while (palindrome! = 0) { 

int remainder=palindrome%10; 

reverse = reverse*10 + remainder; 

palindrome = palindrome/10; 

if (number == reverse) { 

return true; ) 

return false; 


22; 


int number = 10; 

int factorialSum = 1; 

for(int i = 1; i <=number; i++) ( 

factorialSum = factorialSum * i; ) 
System.out.printin("Factorial of " + number + "is " + 
factorialSum); } 


public static String uniqueChars(String str) ( 
String unique = ""; 

for (int i = 0; i < str.length(); i++) ( 

if ('unique.contains("" + str.charAt(i))) { 
unique += str.charAt(i); ) ) 

return unique; )) 


public static void main(String[] args) ( 
Scanner scanznew Scanner (System./n); 
System.ouf.println("How many rows you want in your 
pyramid?"); 

int noOfRows=scan.nextint(); 

int rowCount=1; 

System.ouf.println("Here is your pyramid"); 
for(int i=noOfRows;i>0;i--) ( 

for(int j=1;j<=i;j++) ( 

System. out.print(""); } 

for(int j=1;j<=rowCount;j+t) { 

System. out.print(rowCount+ "");} 
System. out printin(); 

rowCount**; }} 


//Using for loop 
for (int i0; i<names.size();i++) { 


System.out.printin(names.get(i)); ) 


//[Using for each loop 
for (String value: names) { 
System.out.printin(value); ) 


[/[Using Iterator 

Iterator<String> it=names.iterator(); //create/initialize 
Iterator 

while(it.hasNext()) { 

String name=it.next(); 


System.out.printin(name); ) 


[Using while loop 
int count=0; while(names.size()>count) ( 


System.out.printin(names.get(count)); 
count++; } 


String givenz"ghjf878997acaf9797efds &^ &A*4*A"; 
String replaced=given.replaceAll("[a-zA-Z]", ""); 
int alphaCharzgiven.length()-replaced.length(); 
System.out.printin(alphaChar); 


//1st Way 
System.out.printin(String.valueOf(array)); 


//2nd Way 
System.out.printin(Arrays.toString(array)); 


lst Way 

int[] numArray = (5, 7, 11, 15,0, -3}; 
int smallest = 0; 

int largest = 0; 

for (int i = 0; i < numArray.length; i++) { 
if (numArray[i] > largest) ( 

largest = numArray[i]; 

} else { 

smallest = numArray[i]; ) } 
System.out.printin(smallest); 
System.out.printin(largest); 


//2nd Way 

Integer[] array = {7,0,25,-1,5,40}; 

int min = Collections.min(Arrays.asList(array)); 
int max = Collections.max(Arrays.asList(array)); 
System.out.printin("Maximum value is "*max); 
System.out.printin("Minimum value is "+min); 


public static void main(String[] args) ( 
String blogName = "howtodoinjava dot com"; 


char[] chars = blogName.toCharArray(); 
Map<Character, Integer» map = new HashMap<>(); 
for(char c : chars) ( 
if(map.containsKey(c)) ( 
int counter = map.get(c); 
map.put(c, **counter); 
) eise ( 
map.put(c, 1); ) ) 
System.out.printin("Duplicate characters:"); 
//Print duplicate characters 
for(char c : map.keySet()) ( 
if(map.get(c) > 1) { 
System.out.printin(c); } ) 


public class StringContainsVowels { 
public static void main(String[] args) { 


System.out.printin(stringContainsVowels("Hello")); // true 


System.out.printin(stringContainsVowels("TV")); // false 
) 
public static boolean stringContainsVowels(String 
input) ( 
return 
input.toLowerCase().matches(".*[aeiou].*"); ) 


public class FibonacciNumbers ( 
public static int fibonacci(int n) ( 
if (n <= 1) 
return n; 
return fibonacci(n - 1) + fibonacci(n - 2); ) 
public static void main(String args[]) ( 
int n = 10; 
System.out.println(fibonacci(n)); ) ) 


public static boolean onlyOddNumbers(List«Integer» 
list) { 

for (int i: list) { 

if (i % 2 == 0) 

return false; 


return true; 


String removeWhiteSpaces(String input){ 

StringBuilder output = new 
StringBuilder(); 

char[] charArray = input.toCharArray(); 

for(char c : charArray) { 

if (1ICharacter.isWhitespace(c)) 
output.append(c); ) 

return output.toString(); ) 


O 


String s = " abc defit"; 
s = s.strip(); 
System.out.printin(s); 


public static long factorial(long n) ( 


if (n == 1) 
return 1; 
else 


return (n * factorial(n - 1); ) 


public static int binarySearch(int arr[], int low, int 
high, int key) ( 
int mid = (low + high) / 2; 
while (low <= high) { 
if (arr[mid] < key) { 
low = mid + 1; 
} else if (arr[mid] == key) { 
return mid; 
} else { 
high = mid - 1; 
} mid = (low + high) / 2; 
} if (low > high) { 
return -1; } 
return -1; } 


int[] array = (1,2, 3, 4,5 y 
int sum = 0; 


sum += ii; 
System.out.printin(sum); 


List<String> list1 = new ArrayList<>(); 
list1.add("1"); 

List<String> list2 = new ArrayList<>(); 
list2.add("2"); 

List«String» mergedList = new ArrayList<>(list1); 
mergedList.addAll(list2); 
System.out.printin(mergedList); // [1, 2] 


String str1 = "abcdABCDabcdABCD"; 
str1 = str1.replace("a 


"mm; 


System.out.printin(str1); / bcdABCDbcdABCD 


public enum ThreadStates { 
START, 
RUNNING, 
WAITING, 
DEAD; } 


class Animal ( 

String color; 
) 
class Cat extends Animal ( 
void meuw() { 
System.out.printin("Meuw"); ) 


} 
Write a Program to show try catch example 
try { 

FilelnputStream fis = new 
FilelnputStream("test.txt"); 
Jcatch(FileNotFoundException e) ( 

e.printStackTrace(); ) 


@Functionallinterface interface Foo ( 
void test(); 


) 


Xpath types: 
m Absolute path - starts with single / 


m Relative path - starts with double // and can be 
anywhere on page 


Xpath for dynamic elements 
m Contains 

m Using OR & AND 

m Starts-with 

m Text() 

m Partial text 

Dynamic: 


e //*[Contains(QOname,'btn')] ^ we have taken the 
‘name’ as an attribute and 'btn' as an partial value 


e //label[starts-with(QGid,' message")] ^ This expression 


will identify all three elements 


e //*[text() ="whatever']— with text function, we find 


the element with exact text match 


It is faster and simpler than XPATH. But it is not as 


flexible as XPATH. 


e Syntax: tag[attribute = ‘value’] 
e Boolean isPresent = driver.findElements(By.yourLocator).size() > 0 


This will return true if at least one element is found 
and false if it does not exist. 


e isDisplayed() method — verifies and returns a true or 


false based on the state of the element whether it is 
displayed or not. It will throw an exception if element 
is not present in DOM. 


driver.findElement(By. id("form submit" )).isDisplayed() ; 


e getText() — method fetches text present in the html 
including sub-elements text. It returns value as string. 


driver.findElement(By. cssSelector(".component" )).getText() ; 


getAttribute(“”) — method gets the value of an 


attribute. 


o in HTML code whatever is present in the left side of 
'z' js an attribute, value on the right side is an 
attribute value. 

driver.findElement (By.id("bruh")).getAttribute ("title"); 


isEnabled() method — verifies and returns a true or 
false based on the state of the element whether it is 
enabled or not. 


.findElement (By.name("btn")).isEnabled(); 


Implicit Wait - is set only once and lasts for the entire 
duration of your webdriver. 


driver.manage().timeouts().implicitlyWait(8, TimeUnit.SECONDS); 


Explicit Wait - is used to tell webdriver to wait for 
certain conditions or the maximum time limit 
before throwing an Exception. 


Wait wait=new WebDriverWait( driver, 10); 
wait.until(ExpectedConditions.presenceOfElementLocated 
(By.name("pw"))); 


Fluent Wait - FluentWait class implements the Wait 
interface in selenium. 

The difference of fluent wait is that, you can define 
how frequently Selenium should check back if 
condition is met. 


e Syntax: 


o Wait<WebDriver> fWait = new 
FluentWait«WebbDriver*? (driver) 


o .withTimeout(Duration.ofSeconds(10)) 
o .pollingEvery(Duration.ofMillis(600)) 


o ,ignoring(NoSuchElementException.class); 


WebElement myDropdown = driver. findElement (By.id("wer")); 
Select dropdown = new Select(myDropdown ); 

List <WebElement> allElements = dropdown. getOptions(); 

for (WebElement element : allElements) ( 


System.out. printin(element.getText()); ) 


e Since the main window we are on also has GU ID, we can get 
it 


o String mainGUID = driver.getWindowHandle(); 


e We can also get window handles of all open windows tabs by 
selenium 


o Set allIGUIDS = driver.getWindowHandles(); 


e Once we know the GUID of a window we can switch control 
to it 


o driver.switchTo().window(guid); 


e After done you can close the new window and pass control 
back to main 


o driver.close(); 


o driver.switchTo().window(mainGUID); 


Alerts are pop up windows that are used to get the 
attention of the user to perform some operation 


e There are 3 types of alerts: 
o Alert 

o Confirmation Dialog 

o Prompt 


e We cannot locate alerts using inspect tools (id, name, 
css, xpath etc..) 


e Alerts are not html windows 
e We handle alerts using: 
o Alert myAlert = driver.switchTo().alert(); 


o By calling switchTo() method, we are passing control of 
selenium from html page to alert popup 


o There are 4 actions we can make with alerts 
o myAlert.accept(); — OK 

o myAlert.dismiss(); — Cancel 

o myAlert.getText(); — Get alert text 


o myAlert.sendKeys("test Text"); — Type into the prompt 


Frame — is an HTML tag and used to divide the same web page 
into various frames/windows. 


By index — driver.switchTo().frame(0) 

o Since the order of frames can change, it is not reliable way 
e By name or ID — driver.switchTo().frame("customlframe"); 
o If these attributes are not present can't use it. 

e By webelement — 


o WebElement 
testFramezdriver.findElement(By.xpath("//* [@class=’tls’]")); 


o driver.switchTo().frame(testFrame) 


We need to switch to outer iframe first, and then switch to 
inner iframe. 


o driver.switchTo().frame("iframe2"); 
o driver.switchTo().frame("iframe1"); 


e You cannot also go between child iframes directly. Have to 
go up to parent and then come down to 


sibling. To switch control back to parent iframe: 
o driver.switchTo().parentFrame(); 
e To switch control back to main html page 


o driver.switchTo().defaultContent (); 


Mouse Actions: build(), click(), clickAndHold(), contextClick(), 
doubleClick(), dragAndDrop(), moveToElement(), perform(), release() 
Keyboard Actions: sendKeys(), keyUp(), keyDown() 


In order to hover over an element, we use: moveToElement() 
method. 


o Action act = new Action(driver); 


act.moveToElement(elem).perform(); 


In order to right click an element or an webpage, we use 
contextClick() method 


o Actions act = new Actions(driver); 


act.contextClick(element).perform(); 


In order to drag and drop element we use dragAndDrop() method 
o WebElement source = driver. findElement (By.xpath("//img")); 
o WebElement target = driver. findElement (By.id("div2")); 


o act.dragAndDrop(source, target). perform(); 


If we want to build series of actions methods, we use build() method 
.-moveToElement(txtUsername) 


.Click() 

-keyDown(txtUsername, Keys.SHIFT) 
.sendKeys(txtUsername, "hello") 
.keyUp(txtUsername, Keys.SHIFT) 


-build().perform(); 


We can also use Actions class to press keys on keyboard 
o Actions act=new Actions(driver); 


o act.sendKeys(Keys.ENTER).build().perform(); 


There are several actions we can do with help of Javascript 
Executor 


e Click an element 
o WebElement button zdriver.findElement(By.name("btnLogin")); 
o JavascriptExecutor js = (JavascriptExecutor)driver; 


o js.executeScript("arguments[0].click();", button); 


e We can scroll the web page, by using JavascriptExecutor: 

o To scroll to the a specific element 

o js.executeScript("arguments[0].scrollintoView(true);", element); 
o To scroll to the end of the page: 


O 


js-executeScript("window.scrollBy(0,document.body.scrollHeight)"); 


e Create an object of FilelnputStream class to read 
excel file 


o FilelnputStream fis = new 
FilelnputStream("C:WMmydata.xlsx"); 


e Create object of XSSFWorkbook class 


o XSSFWorkbook workbook = new XSSFWorkbook(fis); 


e Create object of XSSFWorksheet class 


o XSSFSheet sheet = workbook.getSheetAt(0); 


e Access a given row: 


o XSSFRow row = sheet .getRow(1); 


e Access a given cell: 
o XSSFCell cell = row.getCell(1); 


o String value = cell.getStringCellValue(); 


e Alternatively: 


o String value = sheet 
.getRow(1).getCell(1).getStringCellValue(); 


1. Load and Register the Database Driver 


a. Depending on which database you are using: MySQL, Oracle, 
Postgres etc. 


Class.forName("com.microsoft.sqlserver.jdbc.SQLServerDriver 


7)» 


2. Establish Connection. 


a. Connection 
con=DriverManager.getConnection("jdbc:sqlserver://34.235.0.4: 
1433; 


databaseName=MealBDb", "username", "password"); 


3. Create Statement Object 


a. Statement st- con.createStatement(); 


4. Execute the Statement 


a. ResultSet rs= st.executeQuery("Select * from 
dbo.Expenses"); 


We create an object of JavaFaker class and call methods: 
o Faker faker = new Faker(); 
o String city = faker.address().city(); 


o String name = faker.name().fullName(); 


e For file upload, we just use sendkeys() method and pass 
the directory (file path) in which our 


target file is located. 


e uploadButton.sendKeys("/test-data/city.docx"); 


download popup. 
o case "chrome": 
o WebDriverManager.chromedriver().setup(); 


o HashMapssString, Object» chromePrefs = new 
HashMap<String, Object>(); 


O 

chromePrefs.put("profile.default content settings.popups" 
0); 

3 3 


o chromePrefs.put("download.default directory", 
System.getProperty("user.dir") *"/testdata/downloads/"); 


o ChromeOptions options = new ChromeOptions(); 
o options.setExperimentalOption("prefs", chromePrefs); 


o WebDriver driver = new ChromeDriver(options); 


1. Add Apache Log4J dependency in the POM.XML 


2. Create a new log4j.properties file and save it in the 
Project root folder. 


3. Create an object of Logger class 


a. static final Logger oLog - 
LogManager.getLogger(SelectHelper.class); 


4. Use that object to call logger methods such as: 
a. oLog.info() 
b. oLog.warn() 


c. oLog.debug() 


SQL commands 


SQL COMMANDS 


CHEAT SHEET 


SQL Commands 


The commands in SQL are called Queries and they areof two types: 


Data Definition Query: The statements which defines the 
structure of a database, create tables, specify their keys, 
indexes and so on 
Data manipulation queries: These are the queries which can 
be edited. 

E.g.: Select, updateand insert operation 


ALTER table 


ALTER TABLEtable name 
ADD column name datatype; 


Description 
It is usedto add columns to 
atable in a database 


::31 72:2, 22 WHERE column name 


Create 
TABLE 


SELECT column, nameís) 
FROM table name 

WHERE column 1-value 1 
AND column 2 -value 2; 


It is an operator thatisused 
to combinetwoconditions 


Iti keyword in SQL that 
SELECT column nameAS 'Alias gh nu 

is used torename a column 
FROM table name; 


or table using analiasname 
SELECT column_name{s) 
FROM table_name It is an operator used to 
filter the result within a 
BETWEEN value_1 AND certainrange 
value_2; 
SELECT column_name, 
CASE WHEN condition THEN 
‘Result_1' WHEN condition 
THEN 'Result 2' 
ELSE 'Result 3' 
END 
FROM table name; 


It is a statement used to 
create different outputs 
inside a SELECT statement 


It is a function that takes the 
name of a columnas 
argumentandcountsthe 
number of rows when the 
column isnot NULL 


SELECT COUNT(column name) 
FROM table name; 


CREATE TABLE table name [ 
column, 1 datatype, 
column, 2 datatype, 
column 3 datatype 

k 


It is usedto create anew 
table in a database and 
specify thenameofthe 
table and columnsinside it 


GROUP BY 


INNER JOIN 


IS NULL/ IS 
NOT NULL 


SELECT column, name, COUNT(*) 


FROM table name 
GROUP BY column name; 


Description 


It is an clausein SQL used 
for aggregatefunctions in 
collaboration withthe 
SELECT statement 


SELECT column, name, COUNT(*) It is usedin SQL because 


FROM table name 
GROUP BY column name 


HAVING COUNT(*) > value; 
SELECT column, nameís) 


FROM table 1 
JOIN table 2 
ONtable 1.column name- 


table 2.column name; 
INSERT INTO table name 


the WHERE keyword 
cannot beused in 
aggregating functions 


It is usedto combine rows 
from different tablesifthe 
Join condition goes TRUE 


[column 1, column 2, column 3) It is usedto add new rows 
VALUES [value 1, value 2', toatable 
value 3j; 


SELECT column, names) 
FROM table name 


WHERE column namelS NULL; 


SELECT column, nameís) 
FROM table name 
WHERE column, nameLIKE 


pattern; 
SELECT column, nameís) 


FROM table name 
LIMIT number; 


SELECT MAX(column name) 
FROM table name; 


SELECT MIN(column name) 
FROM table name; 


SELECT column name 
FROM table name 


WHERE column, name-value 1 


OR column name -value 2; 


SELECT column name 
FROM table name 


ORDER BY column name ASC | 


DESC; 


It is a operator used with 


forthe empty values 

It is an special operator 
used withthe WHERE 
clauseto search for a 
specificpatternin a 
column 

It is a clause to specify the 
maximum numberof rows 
the result set musthave 
It is a functionthat takes 
number of columnsasan 
argumentandretum the 
largestvalue among them 
It is a function that takes 
number of columnsasan 
argumentandretum the 
smallest value among 
them 

Itis an operator thatis 
used to filtertheresult set 
tocontain only therows 
where either condition is 
TRUE 

It is a clauseusedto sort 
the result set by a 
particular column either 
numerically or 
alphabeticall 


SELECT column, namels) 
FROM table 1 

i 1112:9 10.1] LEFT JOIN table 2 

ON table_1.column_name= 
table_2.column_name; 


SELECT ROUND(column_name, 
integer) 
FROM table name; 


ROUND 


SELECT column name 
FROM table name; 


SELECT 


SELECT DISTINCT column name 
FROM table name; 


SELECT SUM(column, name) 
FROM table name; 


UPDATEtable name 

SET some column = some value 
WHERE some column = 

some value; 

SELECT column namelís) 

FROM table name 

WHERE column, nameoperator 
value; 

WITH temporary name AS [ 
SELECT * 

FROM table name) 

SELECT * 

FROM temporary name 

WHERE column nameoperator 
value; 


DELETE FROM table name 
WHERE some column = 
some value; 


SELECT AVG(column name) 
FROM table name; 


from different tables even INNER JOIN t2 on condition 
ifthe condition is NOT fOr 44:13-11:19: 11:119 99 Select column cland c2fromtable 
TRUE | from tablet t1 and perform an inner join 
It is a function that takes EELEE 

SELECT c1, c2 
thecolumnnameanda | Baas ee FROM t1 
integer as an argument, LEFT JOIN t2 on condition 


Commands and syntax for Commands and syntax for querying 
querying data from Single Table data from Multiple Table 
SELECT c1, c2 
SELECT c1 FROM t FROM t1 


Description 


It is suedto combine rows 


and roundsthevaluesin a | PrE REAT E a 99 Select column c1and c2fromtable 


column to the number of piZ ITANE t1 and perform a left join between t1 
decimal places specified by andt2 


an integer SELECT c1, c2 

It is a statement that is SELECT c1 FROM t FROM t1 

used tofetch datafroma |. 12:39 74 RIGHT JOIN t2 on condition 
database iyo ade ic bytes Fuses Select column cland c2fromtable 
It is usedto specify that table t, where ci=test t1 and perform aright join between 


tlandt2 

SELECT c1, c2 

FROM t1 

FULL OUTER JOIN t2 on condition 
Select column cland c2fromtable 
t1 and perform afull outer join 


the statementisa query 
which returns unique SELECT c1 FROM t 

values in specified co G ORDER BY c1 ASC (DESC) 

It is function used to ret To select data in columncifrom 


sum of values froma table t eitherin ascending or 


particular column descending order betweenti andi 
SELECT c1, c2 
It is usedto editrows ina | aana ite Jii FROM t1 
table PEER BY c1LIMIT n OFFSET CROSS JOIN t2 
To skip the offset of rows and a xeu mec 
It is a clause used to filter t1 and produce a Cartesian product 


return the next n rows 


the result set toinclude ofrows in a table 
the rows whichwherethe | Ez 5942 he les Grd SELECT c1, c2 
conditionisTRUE FROM t FROM t1, t2 


GROUP BY c1 Select column cland c2fromtable 
CEET ICTA ETEA E t1 and producea Cartesian product 
It is usedto storetheres function of rows in a table 
of a particular query in a SELECT c1, aggregate[c2) SELECT c1, c2 
temporary table using an FROM t FROMt1A 
ee weir cress INNER JOIN t2 Bon condition 
[C ITHEDIUTITCT4- eae S Select column cland c2fromtable 
Teeter re br emer T 1-11. t1 and joinit to itself using INNER 
using ‘HAVING’ clause JOIN clause 


alias 


It is usedto removethe 
rows from a table 


AntelliPaat 


FURTHERMORE: 
SQL Developer, SQL DBA Training Masters Program 


It is usedto aggregate a 
numeric column and 
return its average 


